diff --git a/.cspell/frigate-dictionary.txt b/.cspell/frigate-dictionary.txt index 6e66a4704..f2bcf417a 100644 --- a/.cspell/frigate-dictionary.txt +++ b/.cspell/frigate-dictionary.txt @@ -22,6 +22,7 @@ autotrack autotracked autotracker autotracking +backchannel balena Beelink BGRA @@ -191,6 +192,7 @@ ONVIF openai opencv openvino +overfitting OWASP paddleocr paho @@ -315,4 +317,4 @@ yolo yolonas yolox zeep -zerolatency \ No newline at end of file +zerolatency diff --git a/.cursor/rules/frontend-always-use-translation-files.mdc b/.cursor/rules/frontend-always-use-translation-files.mdc new file mode 100644 index 000000000..35034069b --- /dev/null +++ b/.cursor/rules/frontend-always-use-translation-files.mdc @@ -0,0 +1,6 @@ +--- +globs: ["**/*.ts", "**/*.tsx"] +alwaysApply: false +--- + +Never write strings in the frontend directly, always write to and reference the relevant translations file. \ No newline at end of file diff --git a/.github/DISCUSSION_TEMPLATE/beta-support.yml b/.github/DISCUSSION_TEMPLATE/beta-support.yml new file mode 100644 index 000000000..e342127a0 --- /dev/null +++ b/.github/DISCUSSION_TEMPLATE/beta-support.yml @@ -0,0 +1,129 @@ +title: "[Beta Support]: " +labels: ["support", "triage", "beta"] +body: + - type: markdown + attributes: + value: | + Thank you for testing Frigate beta versions! Use this form for support with beta releases. + + **Note:** Beta versions may have incomplete features, known issues, or unexpected behavior. Please check the [release notes](https://github.com/blakeblackshear/frigate/releases) and [recent discussions][discussions] for known beta issues before submitting. + + Before submitting, read the [beta documentation][docs]. + + [docs]: https://deploy-preview-19787--frigate-docs.netlify.app/ + - type: textarea + id: description + attributes: + label: Describe the problem you are having + description: Please be as detailed as possible. Include what you expected to happen vs what actually happened. + validations: + required: true + - type: input + id: version + attributes: + label: Beta Version + description: Visible on the System page in the Web UI. Please include the full version including the build identifier (eg. 0.17.0-beta1) + placeholder: "0.17.0-beta1" + validations: + required: true + - type: dropdown + id: issue-category + attributes: + label: Issue Category + description: What area is your issue related to? This helps us understand the context. + options: + - Object Detection / Detectors + - Hardware Acceleration + - Configuration / Setup + - WebUI / Frontend + - Recordings / Storage + - Notifications / Events + - Integration (Home Assistant, etc) + - Performance / Stability + - Installation / Updates + - Other + validations: + required: true + - type: textarea + id: config + attributes: + label: Frigate config file + description: This will be automatically formatted into code, so no need for backticks. Remove any sensitive information like passwords or URLs. + render: yaml + validations: + required: true + - type: textarea + id: frigatelogs + attributes: + label: Relevant Frigate log output + description: Please copy and paste any relevant Frigate log output. Include logs before and after your exact error when possible. This will be automatically formatted into code, so no need for backticks. + render: shell + validations: + required: true + - type: textarea + id: go2rtclogs + attributes: + label: Relevant go2rtc log output (if applicable) + description: If your issue involves cameras, streams, or playback, please include go2rtc logs. Logs can be viewed via the Frigate UI, Docker, or the go2rtc dashboard. This will be automatically formatted into code, so no need for backticks. + render: shell + - type: dropdown + id: install-method + attributes: + label: Install method + options: + - Home Assistant Add-on + - Docker Compose + - Docker CLI + - Proxmox via Docker + - Proxmox via TTeck Script + - Windows WSL2 + validations: + required: true + - type: textarea + id: docker + attributes: + label: docker-compose file or Docker CLI command + description: This will be automatically formatted into code, so no need for backticks. Include relevant environment variables and device mappings. + render: yaml + validations: + required: true + - type: dropdown + id: os + attributes: + label: Operating system + options: + - Home Assistant OS + - Debian + - Ubuntu + - Other Linux + - Proxmox + - UNRAID + - Windows + - Other + validations: + required: true + - type: input + id: hardware + attributes: + label: CPU / GPU / Hardware + description: Provide details about your hardware (e.g., Intel i5-9400, NVIDIA RTX 3060, Raspberry Pi 4, etc) + placeholder: "Intel i7-10700, NVIDIA GTX 1660" + - type: textarea + id: screenshots + attributes: + label: Screenshots + description: Screenshots of the issue, System metrics pages, or any relevant UI. Drag and drop or paste images directly. + - type: textarea + id: steps-to-reproduce + attributes: + label: Steps to reproduce + description: If applicable, provide detailed steps to reproduce the issue + placeholder: | + 1. Go to '...' + 2. Click on '...' + 3. See error + - type: textarea + id: other + attributes: + label: Any other information that may be helpful + description: Additional context, related issues, when the problem started appearing, etc. diff --git a/.github/DISCUSSION_TEMPLATE/report-a-bug.yml b/.github/DISCUSSION_TEMPLATE/report-a-bug.yml index a32ee5938..de870ac0f 100644 --- a/.github/DISCUSSION_TEMPLATE/report-a-bug.yml +++ b/.github/DISCUSSION_TEMPLATE/report-a-bug.yml @@ -6,6 +6,8 @@ body: value: | Use this form to submit a reproducible bug in Frigate or Frigate's UI. + **⚠️ If you are running a beta version (0.17.0-beta or similar), please use the [Beta Support template](https://github.com/blakeblackshear/frigate/discussions/new?category=beta-support) instead.** + Before submitting your bug report, please ask the AI with the "Ask AI" button on the [official documentation site][ai] about your issue, [search the discussions][discussions], look at recent open and closed [pull requests][prs], read the [official Frigate documentation][docs], and read the [Frigate FAQ][faq] pinned at the Discussion page to see if your bug has already been fixed by the developers or reported by the community. **If you are unsure if your issue is actually a bug or not, please submit a support request first.** diff --git a/.github/copilot-instructions.md b/.github/copilot-instructions.md new file mode 100644 index 000000000..f053abe3f --- /dev/null +++ b/.github/copilot-instructions.md @@ -0,0 +1,385 @@ +# GitHub Copilot Instructions for Frigate NVR + +This document provides coding guidelines and best practices for contributing to Frigate NVR, a complete and local NVR designed for Home Assistant with AI object detection. + +## Project Overview + +Frigate NVR is a realtime object detection system for IP cameras that uses: + +- **Backend**: Python 3.13+ with FastAPI, OpenCV, TensorFlow/ONNX +- **Frontend**: React with TypeScript, Vite, TailwindCSS +- **Architecture**: Multiprocessing design with ZMQ and MQTT communication +- **Focus**: Minimal resource usage with maximum performance + +## Code Review Guidelines + +When reviewing code, do NOT comment on: + +- Missing imports - Static analysis tooling catches these +- Code formatting - Ruff (Python) and Prettier (TypeScript/React) handle formatting +- Minor style inconsistencies already enforced by linters + +## Python Backend Standards + +### Python Requirements + +- **Compatibility**: Python 3.13+ +- **Language Features**: Use modern Python features: + - Pattern matching + - Type hints (comprehensive typing preferred) + - f-strings (preferred over `%` or `.format()`) + - Dataclasses + - Async/await patterns + +### Code Quality Standards + +- **Formatting**: Ruff (configured in `pyproject.toml`) +- **Linting**: Ruff with rules defined in project config +- **Type Checking**: Use type hints consistently +- **Testing**: unittest framework - use `python3 -u -m unittest` to run tests +- **Language**: American English for all code, comments, and documentation + +### Logging Standards + +- **Logger Pattern**: Use module-level logger + + ```python + import logging + + logger = logging.getLogger(__name__) + ``` + +- **Format Guidelines**: + - No periods at end of log messages + - No sensitive data (keys, tokens, passwords) + - Use lazy logging: `logger.debug("Message with %s", variable)` +- **Log Levels**: + - `debug`: Development and troubleshooting information + - `info`: Important runtime events (startup, shutdown, state changes) + - `warning`: Recoverable issues that should be addressed + - `error`: Errors that affect functionality but don't crash the app + - `exception`: Use in except blocks to include traceback + +### Error Handling + +- **Exception Types**: Choose most specific exception available +- **Try/Catch Best Practices**: + - Only wrap code that can throw exceptions + - Keep try blocks minimal - process data after the try/except + - Avoid bare exceptions except in background tasks + + Bad pattern: + + ```python + try: + data = await device.get_data() # Can throw + # ❌ Don't process data inside try block + processed = data.get("value", 0) * 100 + result = processed + except DeviceError: + logger.error("Failed to get data") + ``` + + Good pattern: + + ```python + try: + data = await device.get_data() # Can throw + except DeviceError: + logger.error("Failed to get data") + return + + # ✅ Process data outside try block + processed = data.get("value", 0) * 100 + result = processed + ``` + +### Async Programming + +- **External I/O**: All external I/O operations must be async +- **Best Practices**: + - Avoid sleeping in loops - use `asyncio.sleep()` not `time.sleep()` + - Avoid awaiting in loops - use `asyncio.gather()` instead + - No blocking calls in async functions + - Use `asyncio.create_task()` for background operations +- **Thread Safety**: Use proper synchronization for shared state + +### Documentation Standards + +- **Module Docstrings**: Concise descriptions at top of files + ```python + """Utilities for motion detection and analysis.""" + ``` +- **Function Docstrings**: Required for public functions and methods + + ```python + async def process_frame(frame: ndarray, config: Config) -> Detection: + """Process a video frame for object detection. + + Args: + frame: The video frame as numpy array + config: Detection configuration + + Returns: + Detection results with bounding boxes + """ + ``` + +- **Comment Style**: + - Explain the "why" not just the "what" + - Keep lines under 88 characters when possible + - Use clear, descriptive comments + +### File Organization + +- **API Endpoints**: `frigate/api/` - FastAPI route handlers +- **Configuration**: `frigate/config/` - Configuration parsing and validation +- **Detectors**: `frigate/detectors/` - Object detection backends +- **Events**: `frigate/events/` - Event management and storage +- **Utilities**: `frigate/util/` - Shared utility functions + +## Frontend (React/TypeScript) Standards + +### Internationalization (i18n) + +- **CRITICAL**: Never write user-facing strings directly in components +- **Always use react-i18next**: Import and use the `t()` function + + ```tsx + import { useTranslation } from "react-i18next"; + + function MyComponent() { + const { t } = useTranslation(["views/live"]); + return
-
+
-
+
{{label}}؟",
+ "ask_an": "هل هذا الكائن هو {{label}}؟",
+ "ask_full": "هل هذا الكائن هو {{untranslatedLabel}} ({{translatedLabel}})?"
+ }
+ }
+ },
+ "video": {
+ "viewInHistory": "عرض في التاريخ"
+ }
+ },
+ "export": {
+ "time": {
+ "fromTimeline": "اختر من التسلسل الزمني"
}
}
}
diff --git a/web/public/locales/ar/components/filter.json b/web/public/locales/ar/components/filter.json
index e55bedd66..954d69fac 100644
--- a/web/public/locales/ar/components/filter.json
+++ b/web/public/locales/ar/components/filter.json
@@ -3,7 +3,29 @@
"labels": {
"label": "التسميات",
"all": {
- "title": "كل التسميات"
+ "title": "كل التسميات",
+ "short": "المسمّيات"
+ }
+ },
+ "classes": {
+ "label": "فئات",
+ "all": {
+ "title": "جميع الفئات"
+ },
+ "count_one": "{{عدد}} الفئة",
+ "count_other": "{{count}} الفئات"
+ },
+ "zones": {
+ "label": "المناطق",
+ "all": {
+ "title": "جميع المناطق",
+ "short": "المناطق"
+ }
+ },
+ "dates": {
+ "selectPreset": "اختر إعدادًا مسبقًا…",
+ "all": {
+ "title": "جميع التواريخ"
}
}
}
diff --git a/web/public/locales/ar/components/player.json b/web/public/locales/ar/components/player.json
index da1bd4859..5a3e87d29 100644
--- a/web/public/locales/ar/components/player.json
+++ b/web/public/locales/ar/components/player.json
@@ -3,6 +3,27 @@
"noPreviewFound": "لا يوجد معاينة",
"noPreviewFoundFor": "لا يوجد معاينة لـ{{cameraName}}",
"submitFrigatePlus": {
- "title": "هل ترغب بإرسال هذه الصوره الى Frigate+؟"
+ "title": "هل ترغب بإرسال هذه الصوره الى Frigate+؟",
+ "submit": "تقديم"
+ },
+ "livePlayerRequiredIOSVersion": "مطلوب نظام iOS 17.1 أو أكبر لهذا النوع من البث المباشر.",
+ "cameraDisabled": "الكاميرا معطلة",
+ "stats": {
+ "streamType": {
+ "title": "نوع الدفق:",
+ "short": "النوع"
+ },
+ "bandwidth": {
+ "title": "العرض الترددي:",
+ "short": "العرض الترددي"
+ },
+ "latency": {
+ "title": "التأخير:",
+ "value": "{{seconds}} ثانية"
+ }
+ },
+ "streamOffline": {
+ "title": "البث دون اتصال بالإنترنت",
+ "desc": "لم يتم استلام أي إطارات على دفق {{cameraName}} detect، تحقق من سجلات الأخطاء"
}
}
diff --git a/web/public/locales/ar/objects.json b/web/public/locales/ar/objects.json
index bf0ac8737..4aff9d76e 100644
--- a/web/public/locales/ar/objects.json
+++ b/web/public/locales/ar/objects.json
@@ -7,5 +7,16 @@
"person": "شخص",
"bicycle": "دراجة هوائية",
"car": "سيارة",
- "motorcycle": "دراجة نارية"
+ "motorcycle": "دراجة نارية",
+ "airplane": "طائرة",
+ "bus": "حافلة",
+ "traffic_light": "إشارة المرور",
+ "fire_hydrant": "حنفية إطفاء الحريق",
+ "street_sign": "لافتة شارع",
+ "stop_sign": "إشارة توقف",
+ "parking_meter": "عداد موقف سيارات",
+ "train": "قطار",
+ "boat": "زورق",
+ "bench": "مقعدة",
+ "bird": "طائر"
}
diff --git a/web/public/locales/ar/views/classificationModel.json b/web/public/locales/ar/views/classificationModel.json
new file mode 100644
index 000000000..09af34551
--- /dev/null
+++ b/web/public/locales/ar/views/classificationModel.json
@@ -0,0 +1,6 @@
+{
+ "train": {
+ "titleShort": "الأخيرة"
+ },
+ "documentTitle": "تصنيف النماذج - Frigate"
+}
diff --git a/web/public/locales/ar/views/configEditor.json b/web/public/locales/ar/views/configEditor.json
index 10e9cd739..6387006ce 100644
--- a/web/public/locales/ar/views/configEditor.json
+++ b/web/public/locales/ar/views/configEditor.json
@@ -2,5 +2,17 @@
"documentTitle": "محرر الإعدادات - فرايجيت",
"configEditor": "محرر الإعدادات",
"copyConfig": "نسخ الإعدادات",
- "saveAndRestart": "حفظ وإعادة تشغيل"
+ "saveAndRestart": "حفظ وإعادة تشغيل",
+ "safeConfigEditor": "محرر التكوين في ( الوضع الامن )",
+ "safeModeDescription": "أصبح Frigate في الوضع الآمن بسبب خطأ في التحقق من صحة التكوين.",
+ "toast": {
+ "success": {
+ "copyToClipboard": "تم نسخ التكوين إلى الحافظة."
+ },
+ "error": {
+ "savingError": "خطأ في حفظ التكوين"
+ }
+ },
+ "saveOnly": "احفظ فقط",
+ "confirm": "أتود الخروج دون حفظ؟"
}
diff --git a/web/public/locales/ar/views/events.json b/web/public/locales/ar/views/events.json
index 74ec7d7f5..41312c914 100644
--- a/web/public/locales/ar/views/events.json
+++ b/web/public/locales/ar/views/events.json
@@ -4,5 +4,22 @@
"motion": {
"label": "الحركة",
"only": "حركة فقط"
+ },
+ "allCameras": "كافة الكاميرات",
+ "empty": {
+ "alert": "لا توجد تنبيهات لمراجعتها",
+ "detection": "لا توجد عمليات كشف لمراجعتها",
+ "motion": "لم يتم العثور على بيانات الحركة"
+ },
+ "timeline": "التسلسل الزمني",
+ "timeline.aria": "اختر التسلسل الزمني",
+ "events": {
+ "label": "اﻷحداث",
+ "aria": "اختر الأحداث",
+ "noFoundForTimePeriod": "لم يتم العثور على أي أحداث لهذه الفترة الزمنية."
+ },
+ "documentTitle": "مراجعة - Frigate",
+ "recordings": {
+ "documentTitle": "التسجيلات - Frigate"
}
}
diff --git a/web/public/locales/ar/views/explore.json b/web/public/locales/ar/views/explore.json
index e430d47d2..4b54ed113 100644
--- a/web/public/locales/ar/views/explore.json
+++ b/web/public/locales/ar/views/explore.json
@@ -3,6 +3,28 @@
"documentTitle": "اكتشف - فرايجيت",
"generativeAI": "ذكاء اصطناعي مولد",
"exploreIsUnavailable": {
- "title": "المتصفح غير متاح"
+ "title": "المتصفح غير متاح",
+ "embeddingsReindexing": {
+ "context": "يمكن استخدام الاستكشاف بعد انتهاء تضمين الكائنات المتعقبة من إعادة الفهرسة.",
+ "startingUp": "إبتدا التشغيل…",
+ "step": {
+ "thumbnailsEmbedded": "الصور المصغرة المضمنة: ",
+ "descriptionsEmbedded": "الأوصاف المضمنة: ",
+ "trackedObjectsProcessed": "الأشياء المتعقبة التي تمت معالجتها: "
+ },
+ "estimatedTime": "الزمن المتبقي المقدر:",
+ "finishingShortly": "سينتهي قريبًا"
+ },
+ "downloadingModels": {
+ "context": "تقوم Frigate بتنزيل نماذج التضمين اللازمة لدعم ميزة البحث الدلالي. قد يستغرق ذلك عدة دقائق حسب سرعة اتصالك بالإنترنت.",
+ "setup": {
+ "visionModel": "نموذج الرؤية",
+ "visionModelFeatureExtractor": "مستخرج ميزات نموذج الرؤية",
+ "textModel": "نموذج النص"
+ }
+ }
+ },
+ "details": {
+ "timestamp": "الطابع الزمني"
}
}
diff --git a/web/public/locales/ar/views/exports.json b/web/public/locales/ar/views/exports.json
index 6d0c418d6..318ec2fd8 100644
--- a/web/public/locales/ar/views/exports.json
+++ b/web/public/locales/ar/views/exports.json
@@ -1,5 +1,17 @@
{
"search": "بحث",
"noExports": "لا يوجد تصديرات",
- "documentTitle": "التصدير - فرايجيت"
+ "documentTitle": "التصدير - فرايجيت",
+ "deleteExport": "حذف التصدير",
+ "deleteExport.desc": "هل أنت متأكد من رغبتك في حذف{{exportName}}؟",
+ "editExport": {
+ "title": "إعادة تسمية التصدير",
+ "desc": "قم بإدخال اسم جديد لهذا التصدير.",
+ "saveExport": "حفظ التصدير"
+ },
+ "toast": {
+ "error": {
+ "renameExportFailed": "فشل إعادة تسمية التصدير: {{errorMessage}}"
+ }
+ }
}
diff --git a/web/public/locales/ar/views/faceLibrary.json b/web/public/locales/ar/views/faceLibrary.json
index cb515dde3..5a40c8c59 100644
--- a/web/public/locales/ar/views/faceLibrary.json
+++ b/web/public/locales/ar/views/faceLibrary.json
@@ -1,10 +1,108 @@
{
"description": {
- "addFace": "قم بإضافة مجموعة جديدة لمكتبة الأوجه.",
+ "addFace": "أضف مجموعة جديدة إلى مكتبة الوجوه عن طريق رفع صورتك الأولى.",
"invalidName": "أسم غير صالح. يجب أن يشمل الأسم فقط على الحروف، الأرقام، المسافات، الفاصلة العليا، الشرطة التحتية، والشرطة الواصلة.",
"placeholder": "أدخل أسم لهذه المجموعة"
},
"details": {
- "person": "شخص"
+ "person": "شخص",
+ "subLabelScore": "نتيجة العلامة الفرعية",
+ "timestamp": "الطابع الزمني",
+ "unknown": "غير معروف",
+ "scoreInfo": "النتيجة الفرعية هي النتيجة المرجحة لجميع درجات الثقة المعترف بها للوجه، لذلك قد تختلف عن النتيجة الموضحة في اللقطة.",
+ "face": "تفاصيل الوجه",
+ "faceDesc": "تفاصيل الكائن المتتبع الذي أنشأ هذا الوجه"
+ },
+ "documentTitle": "مكتبة الوجوه - Frigate",
+ "uploadFaceImage": {
+ "title": "رفع صورة الوجه",
+ "desc": "قم بتحميل صورة لمسح الوجوه وإدراجها في {{pageToggle}}"
+ },
+ "collections": "المجموعات",
+ "createFaceLibrary": {
+ "title": "إنشاء المجاميع",
+ "desc": "إنشاء مجموعة جديدة",
+ "new": "إضافة وجه جديد",
+ "nextSteps": "لبناء أساس قوي:annotation_offset per ajustar-ho.",
+ "millisecondsToOffset": "Millisegons per l'òfset de detecció d'anotacions per. Per defecte: 0",
+ "tips": "Reduïu el valor si la reproducció del vídeo es troba per davant dels quadres i els punts de ruta, i augmenteu-lo si es troba per darrere. Aquest valor pot ser negatiu.",
+ "toast": {
+ "success": "El desplaçament de l'anotació per {{camera}} s'ha desat al fitxer de configuració."
+ }
+ }
+ },
+ "carousel": {
+ "previous": "Diapositiva anterior",
+ "next": "Dispositiva posterior"
+ }
+ }
}
diff --git a/web/public/locales/ca/views/exports.json b/web/public/locales/ca/views/exports.json
index dfe5de963..dec2726ff 100644
--- a/web/public/locales/ca/views/exports.json
+++ b/web/public/locales/ca/views/exports.json
@@ -13,5 +13,11 @@
"error": {
"renameExportFailed": "Error al canviar el nom de l’exportació: {{errorMessage}}"
}
+ },
+ "tooltip": {
+ "shareExport": "Comparteix l'exportació",
+ "downloadVideo": "Baixa el vídeo",
+ "editName": "Edita el nom",
+ "deleteExport": "Suprimeix l'exportació"
}
}
diff --git a/web/public/locales/ca/views/faceLibrary.json b/web/public/locales/ca/views/faceLibrary.json
index 356691315..069049255 100644
--- a/web/public/locales/ca/views/faceLibrary.json
+++ b/web/public/locales/ca/views/faceLibrary.json
@@ -12,13 +12,15 @@
"collections": "Col·leccions",
"train": {
"empty": "No hi ha intents recents de reconeixement de rostres",
- "title": "Entrenar",
- "aria": "Seleccionar entrenament"
+ "title": "Reconeixements recents",
+ "aria": "Selecciona els reconeixements recents",
+ "titleShort": "Recent"
},
"description": {
- "addFace": "Guia per a agregar una nova colecció a la biblioteca de rostres.",
+ "addFace": "Afegiu una col·lecció nova a la biblioteca de cares pujant la vostra primera imatge.",
"placeholder": "Introduïu un nom per a aquesta col·lecció",
- "invalidName": "Nom no vàlid. Els noms només poden incloure lletres, números, espais, apòstrofs, guions baixos i guionets."
+ "invalidName": "Nom no vàlid. Els noms només poden incloure lletres, números, espais, apòstrofs, guions baixos i guions.",
+ "nameCannotContainHash": "El nom no pot contenir #."
},
"documentTitle": "Biblioteca de rostres - Frigate",
"uploadFaceImage": {
@@ -54,7 +56,7 @@
"selectImage": "Siusplau, selecciona un fixer d'imatge."
},
"maxSize": "Mida màxima: {{size}}MB",
- "dropInstructions": "Arrastra una imatge aquí, o fes clic per a selccionar-ne una"
+ "dropInstructions": "Arrossegueu i deixeu anar o enganxeu una imatge aquí, o feu clic per seleccionar"
},
"button": {
"uploadImage": "Pujar imatge",
@@ -67,7 +69,7 @@
"toast": {
"success": {
"trainedFace": "Rostre entrenat amb èxit.",
- "updatedFaceScore": "Puntació de rostre actualitzada amb èxit.",
+ "updatedFaceScore": "S'ha actualitzat correctament la puntuació de la cara a {{name}} ({{score}}).",
"uploadedImage": "Imatge pujada amb èxit.",
"addFaceLibrary": "{{name}} s'ha afegit amb èxit a la biblioteca de rostres!",
"deletedName_one": "{{count}} rostre s'ha suprimit amb èxit.",
diff --git a/web/public/locales/ca/views/live.json b/web/public/locales/ca/views/live.json
index dd091b7de..94a811d7a 100644
--- a/web/public/locales/ca/views/live.json
+++ b/web/public/locales/ca/views/live.json
@@ -32,7 +32,15 @@
"label": "Fer clic a la imatge per centrar la càmera PTZ"
}
},
- "presets": "Predefinits de la càmera PTZ"
+ "presets": "Predefinits de la càmera PTZ",
+ "focus": {
+ "in": {
+ "label": "Enfoca la càmera PTZ aprop"
+ },
+ "out": {
+ "label": "Enfoca la càmera PTZ lluny"
+ }
+ }
},
"documentTitle": "Directe - Frigate",
"documentTitle.withCamera": "{{camera}} - Directe - Frigate",
@@ -78,8 +86,8 @@
"disable": "Amaga estadístiques de la transmissió"
},
"manualRecording": {
- "title": "Gravació sota demanda",
- "tips": "Iniciar un event manual basat en els paràmetres de retenció de gravació per aquesta càmera.",
+ "title": "Sota demanda",
+ "tips": "Baixeu una instantània o inicieu un esdeveniment manual basat en la configuració de retenció d'enregistrament d'aquesta càmera.",
"playInBackground": {
"label": "Reproduir en segon pla",
"desc": "Habilita aquesta opció per a continuar la transmissió quan el reproductor està amagat."
@@ -122,6 +130,9 @@
"playInBackground": {
"label": "Reproduir en segon pla",
"tips": "Habilita aquesta opció per a contiuar la transmissió tot i que el reproductor estigui ocult."
+ },
+ "debug": {
+ "picker": "Selecció de stream no disponible en mode debug. La vista debug sempre fa servir el stream assignat pel rol de detecció."
}
},
"streamingSettings": "Paràmetres de transmissió",
@@ -135,7 +146,8 @@
"snapshots": "Instantànies",
"autotracking": "Seguiment automàtic",
"objectDetection": "Detecció d'objectes",
- "audioDetection": "Detecció d'àudio"
+ "audioDetection": "Detecció d'àudio",
+ "transcription": "Transcripció d'audio"
},
"history": {
"label": "Mostrar gravacions històriques"
@@ -154,5 +166,34 @@
"label": "Editar grup de càmeres"
},
"exitEdit": "Sortir de l'edició"
+ },
+ "transcription": {
+ "enable": "Habilita la transcripció d'àudio en temps real",
+ "disable": "Deshabilita la transcripció d'àudio en temps real"
+ },
+ "snapshot": {
+ "takeSnapshot": "Descarregar una instantània",
+ "noVideoSource": "No hi ha cap font de video per fer una instantània.",
+ "captureFailed": "Error capturant una instantània.",
+ "downloadStarted": "Inici de baixada d'instantània."
+ },
+ "noCameras": {
+ "title": "No s'ha configurat cap càmera",
+ "description": "Comenceu connectant una càmera a Frigate.",
+ "buttonText": "Afegeix una càmera",
+ "restricted": {
+ "title": "No hi ha càmeres disponibles",
+ "description": "No teniu permís per veure cap càmera en aquest grup."
+ },
+ "default": {
+ "title": "No s'ha configurat cap càmera",
+ "description": "Comenceu connectant una càmera a Frigate.",
+ "buttonText": "Afegeix una càmera"
+ },
+ "group": {
+ "title": "No hi ha càmeres al grup",
+ "description": "Aquest grup de càmeres no té càmeres assignades o habilitades.",
+ "buttonText": "Gestiona els grups"
+ }
}
}
diff --git a/web/public/locales/ca/views/search.json b/web/public/locales/ca/views/search.json
index 3f5940348..71f333180 100644
--- a/web/public/locales/ca/views/search.json
+++ b/web/public/locales/ca/views/search.json
@@ -15,7 +15,8 @@
"max_speed": "Velocitat màxima",
"recognized_license_plate": "Matrícula reconeguda",
"has_clip": "Té Clip",
- "has_snapshot": "Té instantània"
+ "has_snapshot": "Té instantània",
+ "attributes": "Atributs"
},
"searchType": {
"thumbnail": "Miniatura",
@@ -55,12 +56,12 @@
"searchFor": "Buscar {{inputValue}}",
"button": {
"clear": "Netejar cerca",
- "save": "Desar la cerca",
- "delete": "Suprimeix la recerca desada",
- "filterInformation": "Informació de filtre",
+ "save": "Desa la cerca",
+ "delete": "Elimina la recerca desada",
+ "filterInformation": "Informació del filtre",
"filterActive": "Filtres actius"
},
- "trackedObjectId": "ID d'objecte rastrejat",
+ "trackedObjectId": "ID de l'objecte rastrejat",
"placeholder": {
"search": "Cercar…"
},
diff --git a/web/public/locales/ca/views/settings.json b/web/public/locales/ca/views/settings.json
index a94e86bd1..7c90d9190 100644
--- a/web/public/locales/ca/views/settings.json
+++ b/web/public/locales/ca/views/settings.json
@@ -7,9 +7,11 @@
"authentication": "Configuració d'autenticació - Frigate",
"camera": "Paràmetres de càmera - Frigate",
"masksAndZones": "Editor de màscares i zones - Frigate",
- "general": "Paràmetres Generals - Frigate",
+ "general": "Configuració de la interfície d'usuari - Fragata",
"frigatePlus": "Paràmetres de Frigate+ - Frigate",
- "notifications": "Paràmetres de notificació - Frigate"
+ "notifications": "Paràmetres de notificació - Frigate",
+ "cameraManagement": "Gestionar càmeres - Frigate",
+ "cameraReview": "Configuració Revisió de Càmeres - Frigate"
},
"menu": {
"ui": "Interfície d'usuari",
@@ -20,7 +22,11 @@
"notifications": "Notificacions",
"debug": "Depuració",
"frigateplus": "Frigate+",
- "enrichments": "Enriquiments"
+ "enrichments": "Enriquiments",
+ "triggers": "Disparadors",
+ "cameraManagement": "Gestió",
+ "cameraReview": "Revisió",
+ "roles": "Rols"
},
"dialog": {
"unsavedChanges": {
@@ -33,7 +39,7 @@
"noCamera": "Cap càmera"
},
"general": {
- "title": "Paràmetres generals",
+ "title": "Paràmetres de la interfície d'usuari",
"liveDashboard": {
"title": "Panell en directe",
"automaticLiveView": {
@@ -43,6 +49,14 @@
"playAlertVideos": {
"label": "Reproduir vídeos d’alerta",
"desc": "Per defecte, les alertes recents al tauler en directe es reprodueixen com a vídeos petits en bucle. Desactiva aquesta opció per mostrar només una imatge estàtica de les alertes recents en aquest dispositiu/navegador."
+ },
+ "displayCameraNames": {
+ "label": "Mostra sempre els noms de la càmera",
+ "desc": "Mostra sempre els noms de les càmeres en un xip al tauler de visualització en directe multicàmera."
+ },
+ "liveFallbackTimeout": {
+ "label": "Temps d'espera per a la reserva del jugador en directe",
+ "desc": "Quan el flux en viu d'alta qualitat d'una càmera no està disponible, torneu al mode d'amplada de banda baixa després d'aquests molts segons. Per defecte: 3."
}
},
"storedLayouts": {
@@ -108,7 +122,8 @@
"mustBeAtLeastTwoCharacters": "El nom de la zona ha de contenir com a mínim 2 caràcters.",
"mustNotContainPeriod": "El nom de la zona no pot contenir punts.",
"alreadyExists": "Ja existeix una zona amb aquest nom per a aquesta càmera.",
- "mustNotBeSameWithCamera": "El nom de la zona no pot ser el mateix que el nom de la càmera."
+ "mustNotBeSameWithCamera": "El nom de la zona no pot ser el mateix que el nom de la càmera.",
+ "mustHaveAtLeastOneLetter": "El nom de la zona ha de tenir almenys una lletra."
}
},
"inertia": {
@@ -157,7 +172,7 @@
"name": {
"inputPlaceHolder": "Introduïu un nom…",
"title": "Nom",
- "tips": "El nom ha de tenir almenys 2 caràcters i no pot coincidir amb el nom d'una càmera ni amb el d'una altra zona."
+ "tips": "El nom ha de tenir almenys 2 caràcters, ha de tenir almenys una lletra, i no ha de ser el nom d'una càmera o una altra zona en aquesta càmera."
},
"label": "Zones",
"desc": {
@@ -184,7 +199,7 @@
},
"clickDrawPolygon": "Fes click per a dibuixar un polígon a la imatge.",
"toast": {
- "success": "La zona {{zoneName}} ha estat desada. Reinicia Frigate per a aplicar els canvis."
+ "success": "S'ha desat la zona ({{zoneName}})."
}
},
"filter": {
@@ -214,8 +229,8 @@
"clickDrawPolygon": "Fes click per a dibuixar un polígon a la imatge.",
"toast": {
"success": {
- "title": "{{polygonName}} s'ha desat. Reinicia Frigate per a aplicar els canvis.",
- "noName": "La màscara de moviment ha estat desada. Reinicia Frigate per aplicar els canvis."
+ "title": "{{polygonName}} s'ha desat.",
+ "noName": "La màscara de moviment ha estat desada."
}
}
},
@@ -239,8 +254,8 @@
"clickDrawPolygon": "Fes click per a dibuixar un polígon a la imatge.",
"toast": {
"success": {
- "title": "{{polygonName}} s'ha desat. Reinicia Frigate per a aplicar els canvis.",
- "noName": "La màscara d'objectes ha estat desada. Reincia Frigate per a aplicar els canvis."
+ "title": "{{polygonName}} s'ha desat.",
+ "noName": "La màscara d'objectes ha estat desada."
}
},
"context": "Les màscares de filtratge d’objectes s’utilitzen per descartar falsos positius d’un tipus d’objecte concret segons la seva ubicació."
@@ -344,6 +359,43 @@
"detections": "Deteccions ",
"title": "Revisar",
"desc": "Habilita o deshabilita temporalment les alertes i deteccions per a aquesta càmera fins que es reiniciï Frigate. Quan estigui desactivat, no es generaran nous elements de revisió. "
+ },
+ "object_descriptions": {
+ "title": "Descripció d'objectes per IA generativa",
+ "desc": "Activar/desactivar temporalment la IA generativa de descripcions per aquesta càmera. Quan està desactivat, les descripcions d'IA generativa no seran requerides per als objectes seguits per aquesta càmera."
+ },
+ "review_descriptions": {
+ "title": "Revisar las descripcions d'IA generativa",
+ "desc": "Activar/desactivals temporalment les descripcions d'IA generativa per aquesta càmera. Quan estan desactivades, les descripcions d'IA generativa no serán requerides per revisar els items en aquesta càmera."
+ },
+ "addCamera": "Afegir Nova Càmera",
+ "editCamera": "Editar Càmera:",
+ "selectCamera": "Seleccionar Càmera",
+ "backToSettings": "Tornar a la Configuració de Càmera",
+ "cameraConfig": {
+ "add": "Afegir Càmera",
+ "edit": "Editar Càmera",
+ "description": "Configurar la càmera incloent les entrades y rols.",
+ "name": "Nom de Càmera",
+ "nameRequired": "El nom de càmera es necesari",
+ "nameLength": "El nom de la càmera ha de ser com a mínim de 24 caràcters.",
+ "namePlaceholder": "e.x., porta_entrada",
+ "enabled": "Activat",
+ "ffmpeg": {
+ "inputs": "Entrades",
+ "path": "Direcció d'entrada",
+ "pathRequired": "Direcció d'entrada necesaria",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Rols",
+ "rolesRequired": "Com a mínin un rol es necesari",
+ "rolesUnique": "Cada rol (audio, detecció, gravació) pot ser assiganda a una entrada",
+ "addInput": "Afegir una entrada",
+ "removeInput": "Esborrar una entrada",
+ "inputsRequired": "Com a mínim una entrada es necesaria"
+ },
+ "toast": {
+ "success": "La càmera {{cameraName}} s'ha guardat correctament"
+ }
}
},
"motionDetectionTuner": {
@@ -414,12 +466,25 @@
"tips": "Caixes de moviment
Es sobreposaran requadres vermells a les àrees del fotograma on actualment s’estigui detectant moviment.
" }, "detectorDesc": "Frigate fa servir els teus detectors ({{detectors}}) per a detectar objectes a les imatges de la teva càmera.", - "desc": "La vista de depuració mostra en temps real els objectes rastrejats i les seves estadístiques. La llista d’objectes mostra un resum amb retard temporal dels objectes detectats." + "desc": "La vista de depuració mostra en temps real els objectes rastrejats i les seves estadístiques. La llista d’objectes mostra un resum amb retard temporal dels objectes detectats.", + "openCameraWebUI": "Obrir la interficie d'usuari de {{camera}}", + "audio": { + "title": "Audio", + "noAudioDetections": "No hi ha deteccions d'audio", + "score": "puntuació", + "currentRMS": "RMS Actual", + "currentdbFS": "dbFS Actual" + }, + "paths": { + "title": "Rutes", + "desc": "Mostrar els punts significatius de la ruta dels objectes seguits", + "tips": "Rutes
Les línies i cercles indicarán els punts significatius dels objectes seguits durant el seu cicle de vida.
" + } }, "users": { "table": { - "username": "Nom d'usuari", - "password": "Contrasenya", + "username": "Usuari", + "password": "Restableix la contrasenya", "deleteUser": "Suprimir usuari", "noUsers": "No s'han trobat usuaris.", "changeRole": "Canviar la funció d’usuari", @@ -462,7 +527,16 @@ "notMatch": "Les contrasenyes no coincideixen", "match": "Les contrasenyes coincideixen", "placeholder": "Introdueix la contrasenya", - "title": "Contrasenya" + "title": "Contrasenya", + "show": "Mostra contrasenya", + "hide": "Amaga contrasenya", + "requirements": { + "title": "Requisits contrasenya:", + "length": "Com a mínim 12 carácters", + "uppercase": "Com a mínim una majúscula", + "digit": "Com a mínim un digit", + "special": "Com a mínim un carácter especial (!@#$%^&*(),.?\":{}|<>)" + } }, "newPassword": { "title": "Nova contrasenya", @@ -472,14 +546,23 @@ } }, "usernameIsRequired": "El nom d'usuari és obligatori", - "passwordIsRequired": "La contrasenya és obligatoria" + "passwordIsRequired": "La contrasenya és obligatoria", + "currentPassword": { + "title": "Constrasenya actual", + "placeholder": "Entra l'actual contrasenya" + } }, "passwordSetting": { "updatePassword": "Contrasenya actualitzada per {{username}}", "setPassword": "Estableix Contrasenya", "cannotBeEmpty": "La contrasenya no pot ser buida", "doNotMatch": "Les contrasenyes no coincideixen", - "desc": "Crea un nova contrasenya segura per protegir aquest compte." + "desc": "Crea un nova contrasenya segura per protegir aquest compte.", + "currentPasswordRequired": "L'actual contrasenya es requerida", + "incorrectCurrentPassword": "L'actual contrasenya es incorrecte", + "passwordVerificationFailed": "Falla en la verificació de la contrasenya", + "multiDeviceWarning": "Serà necesari loguejarte en qualsevol altre dispositiu en que estiguis loguejat en {{refresh_time}}.", + "multiDeviceAdmin": "També pots forçar a tots els usuaris a tornar a autenticar-se immediatament rotant el teu secret JWT." }, "deleteUser": { "title": "Suprimir usuari", @@ -492,7 +575,8 @@ "admin": "Administrador", "adminDesc": "Accés complet a totes les funcionalitats.", "intro": "Selecciona el rol adequat per a aquest usuari:", - "viewerDesc": "Limitat només a panells en directe, revisió, exporació i exportació." + "viewerDesc": "Limitat només a panells en directe, revisió, exporació i exportació.", + "customDesc": "Rol personalitzat per accés específic a una cámera." }, "title": "Canviar la funció d’usuari", "desc": "Actualitzar permisos per a {{username}}", @@ -511,7 +595,7 @@ "title": "Gestió d'usuaris", "desc": "Gestioneu els comptes d'usuari d'aquesta instància de Frigate." }, - "updatePassword": "Actualitzar contrasenya" + "updatePassword": "Restableix la contrasenya" }, "frigatePlus": { "snapshotConfig": { @@ -612,11 +696,553 @@ "title": "Classificació d'ocells", "desc": "La classificació d’ocells identifica ocells coneguts mitjançant un model TensorFlow quantitzat. Quan es reconeix un ocell conegut, el seu nom comú s’afegeix com a subetiqueta. Aquesta informació es mostra a la interfície d’usuari, als filtres i també a les notificacions." }, - "title": "Parmàmetres complementaris", + "title": "Configuració dels enriquiments", "toast": { "error": "No s'han pogut guardar els canvis de configuració: {{errorMessage}}", "success": "Els paràmetres complementaris s'han desat. Reinicia Frigate per aplicar els canvis." }, "restart_required": "És necessari reiniciar (Han cambiat paràmetres complementaris)" + }, + "triggers": { + "table": { + "actions": "Accions", + "noTriggers": "No hi ha disparadors configurats en aquesta càmera.", + "edit": "Editar", + "deleteTrigger": "Esborrar Disparador", + "lastTriggered": "Últim Disparo", + "name": "Nom", + "type": "Tipus", + "content": "Contingut", + "threshold": "Llindar" + }, + "type": { + "thumbnail": "Miniatura", + "description": "Descripció" + }, + "actions": { + "alert": "Marcar com Alerta", + "notification": "Enviar Notificació", + "sub_label": "Afegeix una subetiqueta", + "attribute": "Afegeix un atribut" + }, + "dialog": { + "createTrigger": { + "title": "Crear Disparador", + "desc": "Crear disparador per una càmera {{camera}}" + }, + "editTrigger": { + "title": "Editar Disparador", + "desc": "Editar la configuració per al disparador de càmera {{camera}}" + }, + "deleteTrigger": { + "title": "Esborrar Disparador", + "desc": "Estas segur que vols esborrar el disparador {{triggerName}}? Aquesta acció no es pot desfer." + }, + "form": { + "name": { + "title": "Nom", + "placeholder": "Anomena aquest activador", + "error": { + "minLength": "El camp ha de tenir almenys 2 caràcters.", + "invalidCharacters": "El camp només pot contenir lletres, números, guions baixos i guions.", + "alreadyExists": "El disparador amb aquest nom ja existeix per aquesta càmera." + }, + "description": "Introduïu un nom o una descripció únics per a identificar aquest activador" + }, + "enabled": { + "description": "Activar o desactivar aquest disparador" + }, + "type": { + "title": "Tipus", + "placeholder": "Selecciona un tipus de disparador", + "description": "Activa quan es detecta una descripció similar d'un objecte rastrejat", + "thumbnail": "Activa quan es detecti una miniatura d'objecte rastrejada similar" + }, + "content": { + "title": "Contingut", + "imagePlaceholder": "Selecciona una miniatura", + "textPlaceholder": "Entra el contingut de text", + "imageDesc": "Només es mostren les 100 miniatures més recents. Si no podeu trobar la miniatura desitjada, reviseu els objectes anteriors a Explora i configureu un activador des del menú.", + "textDesc": "Entra el text per disparar aquesta acció quan es detecti una descripció d'objecte a rastrejar similar.", + "error": { + "required": "Contigunt requerit." + } + }, + "threshold": { + "title": "Llindar", + "error": { + "min": "El llindar ha de ser mínim 0", + "max": "El llindar ha de ser máxim 1" + }, + "desc": "Estableix el llindar de similitud per a aquest activador. Un llindar més alt significa que es requereix una coincidència més propera per disparar el disparador." + }, + "actions": { + "title": "Accions", + "desc": "Per defecte, Frigate dispara un missatge MQTT per a tots els activadors. Subetiquetes afegeix el nom de l'activador a l'etiqueta de l'objecte. Els atributs són metadades cercables emmagatzemades per separat a les metadades de l'objecte rastrejat.", + "error": { + "min": "S'ha de seleccionar una acció com a mínim." + } + }, + "friendly_name": { + "title": "Nom amistós", + "placeholder": "Nom o descripció d'aquest disparador", + "description": "Un nom opcional amistós o text descriptiu per a aquest activador." + } + } + }, + "toast": { + "success": { + "createTrigger": "El disparador {{name}} s'ha creat existosament.", + "updateTrigger": "El disparador {{name}} s'ha actualitzat correctament.", + "deleteTrigger": "El disparador {{name}} s'ha borrat correctament." + }, + "error": { + "createTriggerFailed": "Error al crear el disparador: {{errorMessage}}", + "updateTriggerFailed": "Error a l'actualitzar el disparador: {{errorMessage}}", + "deleteTriggerFailed": "Error a l'esborrar el disparador: {{errorMessage}}" + } + }, + "documentTitle": "Disparadors", + "management": { + "title": "Activadors", + "desc": "Gestionar els disparadors de {{camera}}. Usa els tipus de miniatures per disparar miniatures similars a l'objecte a seguir seleccionat, i el tipus de descripció per disparar en cas de descripcions similars a l'especificada." + }, + "addTrigger": "Afegir disaprador", + "semanticSearch": { + "desc": "La cerca semàntica ha d'estar activada per a utilitzar els activadors.", + "title": "La cerca semàntica està desactivada" + }, + "wizard": { + "title": "Crea un activador", + "step1": { + "description": "Configura la configuració bàsica per al vostre activador." + }, + "step2": { + "description": "Configura el contingut que activarà aquesta acció." + }, + "step3": { + "description": "Configura el llindar i les accions d'aquest activador." + }, + "steps": { + "nameAndType": "Nom i tipus", + "configureData": "Configura les dades", + "thresholdAndActions": "Llindar i accions" + } + } + }, + "roles": { + "dialog": { + "form": { + "cameras": { + "required": "Almenys has de seleccionar una càmera.", + "title": "Càmeres", + "desc": "Selecciona les càmeres que tingui accés aquest rol. Com a mínim s'ha de seleccionar una càmera." + }, + "role": { + "title": "Nom del Rol", + "placeholder": "Entra el nom del rol", + "desc": "Només lletres, números, els punts i subrallats están permesos.", + "roleIsRequired": "Nom del Rol requerit", + "roleOnlyInclude": "El nom de Rol només pot incloure lletres, nombres, . o _", + "roleExists": "Ja existeis un rol amb aquest nom." + } + }, + "createRole": { + "title": "Crear nou Rol", + "desc": "Afegir nou rol y especificar permisos d'accés." + }, + "editCameras": { + "title": "Editar Càmeres Rol", + "desc": "Actualitza l'acces a les càmeres per al rol {{role}}." + }, + "deleteRole": { + "title": "Eliminar Rol", + "desc": "Aquesta acció no pot ser restablerta. S'esborrarà permenentment el rol y els usuaris asignats amb aquest rol de 'visor', que els dona accés a totes les càmeres.", + "warn": "Estas segur que vols eliminar {{role}}?", + "deleting": "Eliminant..." + } + }, + "management": { + "title": "Gestió del Rols de Visors", + "desc": "Gestiona els rols visors personalitzats y els seus permisos d'accés per aquesta instancia de Frigate." + }, + "addRole": "Afegir Rol", + "table": { + "role": "Rol", + "cameras": "Càmeres", + "actions": "Accions", + "noRoles": "No s'han trobat rols personalitzats.", + "editCameras": "Editar Càmeres", + "deleteRole": "Eliminar Rol" + }, + "toast": { + "success": { + "createRole": "Rol {{role}} creat exitosament", + "updateCameras": "Càmeres actualitzades per al rol {{role}}", + "deleteRole": "Rol {{role}} eliminat exitosament", + "userRolesUpdated_one": "{{count}} l'usuari assignat a aquest rol s'ha actualitzat a 'visor', que té accés a totes les càmeres.", + "userRolesUpdated_many": "{{count}} usuaris assignats a aquest rol s'han actualitzat a 'visor', que té accés a totes les càmeres.", + "userRolesUpdated_other": "{{count}} usuaris assignats a aquest rol s'han actualitzat a 'visor', que té accés a totes les càmeres." + }, + "error": { + "createRoleFailed": "Error al crear el rol: {{errorMessage}}", + "updateCamerasFailed": "Error a l'actualitzar les càmeres: {{errorMessage}}", + "deleteRoleFailed": "Error a l'eliminar el rol: {{errorMessage}}", + "userUpdateFailed": "Error a l'actualitzar els ros d'usuari: {{errorMessage}}" + } + } + }, + "cameraWizard": { + "title": "Afegir Càmera", + "description": "Seguiu els passos de sota per afegir una nova càmera a la instal·lació.", + "steps": { + "nameAndConnection": "Nom i connexió", + "streamConfiguration": "Configuració de stream", + "validationAndTesting": "Validació i proves", + "probeOrSnapshot": "Prova o instantània" + }, + "step1": { + "cameraBrand": "Marca de la càmera", + "description": "Introduïu els detalls de la càmera i trieu provar la càmera o seleccionar manualment la marca.", + "cameraName": "Nom de la càmera", + "cameraNamePlaceholder": "p. ex., vista general de la porta davantera o de la barra posterior", + "host": "Adreça de l'amfitrió/IP", + "port": "Port", + "username": "Nom d'usuari", + "usernamePlaceholder": "Opcional", + "password": "Contrasenya", + "passwordPlaceholder": "Opcional", + "selectTransport": "Selecciona el protocol de transport", + "brandInformation": "Informació de marca", + "brandUrlFormat": "Per a càmeres amb el format d'URL RTSP com: {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://usuari:contrasenya@host:port/ruta", + "testConnection": "Prova la connexió", + "testSuccess": "Prova de connexió correcta!", + "testFailed": "Ha fallat la prova de connexió. Si us plau, comproveu la vostra entrada i torneu-ho a provar.", + "streamDetails": "Detalls del flux", + "warnings": { + "noSnapshot": "No s'ha pogut obtenir una instantània del flux configurat." + }, + "errors": { + "brandOrCustomUrlRequired": "Seleccioneu una marca de càmera amb host/IP o trieu 'Altres' amb un URL personalitzat", + "nameRequired": "Es requereix el nom de la càmera", + "nameLength": "El nom de la càmera ha de tenir 64 caràcters o menys", + "invalidCharacters": "El nom de la càmera conté caràcters no vàlids", + "nameExists": "El nom de la càmera ja existeix", + "brands": { + "reolink-rtsp": "No es recomana Reolink RST. Es recomana habilitar HTTP a la configuració de la càmera i reiniciar l'assistent de la càmera." + }, + "customUrlRtspRequired": "Els URL personalitzats han de començar amb \"rtsp://\". Es requereix configuració manual per a fluxos de càmera no RTSP." + }, + "selectBrand": "Seleccioneu la marca de la càmera per a la plantilla d'URL", + "customUrl": "URL de flux personalitzat", + "docs": { + "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras" + }, + "testing": { + "probingMetadata": "S'estan provant les metadades de la càmera...", + "fetchingSnapshot": "S'està recuperant la instantània de la càmera..." + }, + "connectionSettings": "Configuració de la connexió", + "detectionMethod": "Mètode de detecció de flux", + "onvifPort": "ONVIF Port", + "probeMode": "Càmera de prova", + "manualMode": "Selecció manual", + "detectionMethodDescription": "Proveu la càmera amb ONVIF (si és compatible) per trobar URL de flux de càmera, o seleccioneu manualment la marca de càmera per utilitzar URL predefinits. Per a introduir un URL RTSP personalitzat, trieu el mètode manual i seleccioneu \"Altres\".", + "onvifPortDescription": "Per a les càmeres que suporten ONVIF, això sol ser 80 o 8080.", + "useDigestAuth": "Utilitza l'autenticació digest", + "useDigestAuthDescription": "Usa l'autenticació de resum HTTP per a ONVIF. Algunes càmeres poden requerir un nom d'usuari/contrasenya ONVIF dedicat en lloc de l'usuari administrador estàndard." + }, + "save": { + "failure": "S'ha produït un error en desar {{cameraName}}.", + "success": "S'ha desat correctament la càmera nova {{cameraName}}." + }, + "testResultLabels": { + "resolution": "Resolució", + "video": "Vídeo", + "audio": "Àudio", + "fps": "FPS" + }, + "commonErrors": { + "noUrl": "Proporcioneu un URL de flux vàlid", + "testFailed": "Ha fallat la prova de flux: {{error}}" + }, + "step2": { + "description": "Proveu la càmera per als fluxos disponibles o configureu la configuració manual basada en el mètode de detecció seleccionat.", + "streamsTitle": "Fluxos de la càmera", + "addStream": "Afegeix un flux", + "addAnotherStream": "Afegeix un altre flux", + "streamTitle": "Flux {{number}}", + "streamUrl": "URL del flux", + "url": "URL", + "resolution": "Resolució", + "selectResolution": "Selecciona la resolució", + "quality": "Qualitat", + "selectQuality": "Selecciona la qualitat", + "roleLabels": { + "detect": "Detecció d'objectes", + "record": "Enregistrament", + "audio": "Àudio" + }, + "testStream": "Prova la connexió", + "testSuccess": "Prova de connexió correcta!", + "testFailed": "Ha fallat la prova de connexió. Si us plau, comproveu la vostra entrada i torneu-ho a provar.", + "testFailedTitle": "Ha fallat la prova", + "connected": "Connectat", + "notConnected": "No connectat", + "featuresTitle": "Característiques", + "go2rtc": "Redueix les connexions a la càmera", + "detectRoleWarning": "Almenys un flux ha de tenir el rol de \"detecte\" per continuar.", + "rolesPopover": { + "title": "Rols de flux", + "detect": "Canal principal per a la detecció d'objectes.", + "record": "Desa els segments del canal de vídeo basats en la configuració.", + "audio": "Canal per a la detecció basada en àudio." + }, + "featuresPopover": { + "title": "Característiques del flux", + "description": "Utilitzeu el restreaming go2rtc per reduir les connexions a la càmera." + }, + "roles": "Rols", + "streamUrlPlaceholder": "rtsp://usuari:contrasenya@host:port/ruta", + "streamDetails": "Detalls del flux", + "probing": "Provant càmera...", + "retry": "Intentar de nou", + "testing": { + "probingMetadata": "S'estan provant les metadades de la càmera...", + "fetchingSnapshot": "S'està recuperant la instantània de la càmera..." + }, + "probeFailed": "No s'ha pogut provar la càmera: {{error}}", + "probingDevice": "Provant dispositiu...", + "probeSuccessful": "Prova exitosa", + "probeError": "Error de prova", + "probeNoSuccess": "La prova no ha tingut èxit", + "deviceInfo": "Informació del dispositiu", + "manufacturer": "Fabricant", + "model": "Model", + "firmware": "Firmware", + "profiles": "Perfils", + "ptzSupport": "Suport PTZ", + "autotrackingSupport": "Implementació de seguiment automàtic", + "presets": "Predefinits", + "rtspCandidates": "Candidats RTSP", + "rtspCandidatesDescription": "S'han trobat els següents URL RTSP de la sonda de la càmera. Proveu la connexió per a veure les metadades del flux.", + "noRtspCandidates": "No s'ha trobat cap URL RTSP a la càmera. Les vostres credencials poden ser incorrectes, o la càmera pot no admetre ONVIF o el mètode utilitzat per recuperar els URL RTSP. Torneu enrere i introduïu l'URL RTSP manualment.", + "candidateStreamTitle": "Candidat {{number}}", + "useCandidate": "Utilitza", + "uriCopy": "Copia", + "uriCopied": "URI copiat al porta-retalls", + "testConnection": "Prova la connexió", + "toggleUriView": "Feu clic per a commutar la vista completa de l'URI", + "errors": { + "hostRequired": "Es requereix l'adreça de l'amfitrió/IP" + } + }, + "step3": { + "none": "Cap", + "error": "Error", + "saveAndApply": "Desa una càmera nova", + "saveError": "Configuració no vàlida. Si us plau, comproveu la configuració.", + "issues": { + "title": "Validació del flux", + "videoCodecGood": "El còdec de vídeo és {{codec}}.", + "audioCodecGood": "El còdec d'àudio és {{codec}}.", + "noAudioWarning": "No s'ha detectat cap àudio per a aquest flux, els enregistraments no tindran àudio.", + "audioCodecRecordError": "El còdec d'àudio AAC és necessari per a suportar l'àudio en els enregistraments.", + "audioCodecRequired": "Es requereix un flux d'àudio per admetre la detecció d'àudio.", + "restreamingWarning": "Reduir les connexions a la càmera per al flux de registre pot augmentar lleugerament l'ús de la CPU.", + "dahua": { + "substreamWarning": "El substream 1 està bloquejat a una resolució baixa. Moltes càmeres Dahua / Amcrest / EmpireTech suporten subfluxos addicionals que han d'estar habilitats a la configuració de la càmera. Es recomana comprovar i utilitzar aquests corrents si estan disponibles." + }, + "hikvision": { + "substreamWarning": "El substream 1 està bloquejat a una resolució baixa. Moltes càmeres Hikvision suporten subfluxos addicionals que han d'estar habilitats a la configuració de la càmera. Es recomana comprovar i utilitzar aquests corrents si estan disponibles." + }, + "resolutionHigh": "Una resolució de {{resolution}} pot causar un ús més gran dels recursos.", + "resolutionLow": "Una resolució de {{resolution}} pot ser massa baixa per a la detecció fiable d'objectes petits." + }, + "description": "Configura els rols de flux i afegeix fluxos addicionals per a la càmera.", + "validationTitle": "Validació del flux", + "connectAllStreams": "Connecta tots els fluxos", + "reconnectionSuccess": "S'ha reconnectat correctament.", + "reconnectionPartial": "Alguns fluxos no s'han pogut tornar a connectar.", + "streamUnavailable": "La vista prèvia del flux no està disponible", + "reload": "Torna a carregar", + "connecting": "Connectant...", + "streamTitle": "Flux {{number}}", + "valid": "Vàlid", + "failed": "Ha fallat", + "notTested": "No provat", + "connectStream": "Connecta", + "connectingStream": "Connectant", + "disconnectStream": "Desconnecta", + "estimatedBandwidth": "Amplada de banda estimad", + "roles": "Rols", + "streamValidated": "El flux {{number}} s'ha validat correctament", + "streamValidationFailed": "Ha fallat la validació del flux {{number}}", + "ffmpegModule": "Usa el mode de compatibilitat del flux", + "ffmpegModuleDescription": "Si el flux no es carrega després de diversos intents, proveu d'activar-ho. Quan està activat, Frigate utilitzarà el mòdul ffmpeg amb go2rtc. Això pot proporcionar una millor compatibilitat amb alguns fluxos de càmera.", + "streamsTitle": "Fluxos de la càmera", + "addStream": "Afegeix un flux", + "addAnotherStream": "Afegeix un altre flux", + "streamUrl": "URL del flux", + "streamUrlPlaceholder": "rtsp://usuari:contrasenya@host:port/ruta", + "selectStream": "Selecciona un flux", + "searchCandidates": "Cerca candidats...", + "noStreamFound": "No s'ha trobat cap flux", + "url": "URL", + "resolution": "Resolució", + "selectResolution": "Selecciona la resolució", + "quality": "Qualitat", + "selectQuality": "Selecciona la qualitat", + "roleLabels": { + "detect": "Detecció d'objectes", + "record": "Enregistrament", + "audio": "Àudio" + }, + "testStream": "Prova la connexió", + "testSuccess": "Prova de flux amb èxit!", + "testFailed": "Ha fallat la prova del flux", + "testFailedTitle": "Ha fallat la prova", + "connected": "Connectat", + "notConnected": "No connectat", + "featuresTitle": "Característiques", + "go2rtc": "Redueix les connexions a la càmera", + "detectRoleWarning": "Almenys un flux ha de tenir el rol de \"detecte\" per continuar.", + "rolesPopover": { + "title": "Roles de flux", + "detect": "Canal principal per a la detecció d'objectes.", + "record": "Desa els segments del canal de vídeo basats en la configuració.", + "audio": "Canal per a la detecció basada en àudio." + }, + "featuresPopover": { + "title": "Característiques del flux", + "description": "Utilitzeu el restreaming go2rtc per reduir les connexions a la càmera." + } + }, + "step4": { + "description": "Validació i anàlisi final abans de desar la nova càmera. Connecta cada flux abans de desar-lo.", + "validationTitle": "Validació del flux", + "connectAllStreams": "Connecta tots els fluxos", + "reconnectionSuccess": "S'ha reconnectat correctament.", + "reconnectionPartial": "Alguns fluxos no s'han pogut tornar a connecta.", + "streamUnavailable": "La vista prèvia del flux no està disponible", + "reload": "Torna a carregar", + "connecting": "S'està connectant...", + "streamTitle": "Flux {{number}}", + "valid": "Vàlid", + "failed": "Ha fallat", + "notTested": "No provat", + "connectStream": "Connecta", + "connectingStream": "Connectant", + "disconnectStream": "Desconnecta", + "estimatedBandwidth": "Amplada de banda estimada", + "roles": "Roles", + "ffmpegModule": "Usa el mode de compatibilitat del flux", + "ffmpegModuleDescription": "Si el flux no es carrega després de diversos intents, proveu d'activar-ho. Quan està activat, Frigate utilitzarà el mòdul ffmpeg amb go2rtc. Això pot proporcionar una millor compatibilitat amb alguns fluxos de càmera.", + "none": "Cap", + "error": "Error", + "streamValidated": "El flux {{number}} s'ha validat correctament", + "streamValidationFailed": "Ha fallat la validació del flux {{number}}", + "saveAndApply": "Desa una càmera nova", + "saveError": "Configuració no vàlida. Si us plau, comproveu la configuració.", + "issues": { + "title": "Validació del flux", + "videoCodecGood": "El còdec de vídeo és {{codec}}.", + "audioCodecGood": "El còdec d'àudio és {{codec}}.", + "resolutionHigh": "Una resolució de {{resolution}} pot causar un ús més gran dels recursos.", + "resolutionLow": "Una resolució de {{resolution}} pot ser massa baixa per a la detecció fiable d'objectes petits.", + "noAudioWarning": "No s'ha detectat cap àudio per a aquest flux, els enregistraments no tindran àudio.", + "audioCodecRecordError": "El còdec d'àudio AAC és necessari per a suportar l'àudio en els enregistraments.", + "audioCodecRequired": "Es requereix un flux d'àudio per admetre la detecció d'àudio.", + "restreamingWarning": "Reduir les connexions a la càmera per al flux de registre pot augmentar lleugerament l'ús de la CPU.", + "brands": { + "reolink-rtsp": "No és racomana utilitzar Reolink RSTP. Activeu HTTP a la configuració del microprogramari de la càmera i reinicieu l'assistent.", + "reolink-http": "Els fluxos HTTP de reenllaç haurien d'utilitzar FFmpeg per a una millor compatibilitat. Habilita «Utilitza el mode de compatibilitat del flux» per a aquest flux." + }, + "dahua": { + "substreamWarning": "El substream 1 està bloquejat a una resolució baixa. Moltes càmeres Dahua / Amcrest / EmpireTech suporten subfluxos addicionals que han d'estar habilitats a la configuració de la càmera. Es recomana comprovar i utilitzar aquests corrents si estan disponibles." + }, + "hikvision": { + "substreamWarning": "El substream 1 està bloquejat a una resolució baixa. Moltes càmeres Hikvision suporten subfluxos addicionals que han d'estar habilitats a la configuració de la càmera. Es recomana comprovar i utilitzar aquests corrents si estan disponibles." + } + } + } + }, + "cameraManagement": { + "title": "Gestiona les càmeres", + "addCamera": "Afegeix una càmera nova", + "editCamera": "Edita la càmera:", + "selectCamera": "Selecciona una càmera", + "backToSettings": "Torna a la configuració de la càmera", + "streams": { + "title": "Habilita / Inhabilita les càmeres", + "desc": "Inhabilita temporalment una càmera fins que es reiniciï la fragata. La inhabilitació d'una càmera atura completament el processament de Frigate dels fluxos d'aquesta càmera. La detecció, l'enregistrament i la depuració no estaran disponibles.Boxy oblastí zájmu
Jasně zelené boxy budou překryty na oblastech zájmu ve snímku, které jsou odesílány detektoru objektů.
" }, - "title": "Ladit", + "title": "Ladění", "detectorDesc": "Frigate používá vaše detektory {{detectors}} k detekci objektů ve streamu vašich kamer.", - "objectList": "Seznam Objektů", + "objectList": "Seznam objektů", "boundingBoxes": { "title": "Ohraničující rámečky", "desc": "Zobrazit ohraničující rámečky okolo sledovaných objektů", @@ -394,7 +407,7 @@ "title": "Masky detekce pohybu", "desc": "Zobrazit polygony masek detekce pohybu" }, - "debugging": "Ledění", + "debugging": "Ladění", "desc": "Ladicí zobrazení ukazuje sledované objekty a jejich statistiky v reálném čase. Seznam objektů zobrazuje časově zpožděný přehled detekovaných objektů.", "motion": { "title": "Rámečky detekce pohybu", @@ -403,13 +416,26 @@ }, "noObjects": "Žádné objekty", "objectShapeFilterDrawing": { - "title": "Kreslení Filtru Tvaru Objektu", + "title": "Vykreslení filtru tvaru objektu", "desc": "Nakreslete na obrázek obdélník pro zobrazení informací o ploše a poměru stran", "tips": "Povolte tuto možnost pro nakreslení obdélníku na obraz kamery, který zobrazí jeho plochu a poměr stran. Tyto hodnoty pak můžete použít pro nastavení parametrů tvarového filtru objektu ve vaší konfiguraci.", "document": "Přečtěte si dokumentaci ", "score": "Skóre", "ratio": "Poměr", "area": "Oblast" + }, + "openCameraWebUI": "Otevřít webové rozhraní {{camera}}", + "audio": { + "title": "Zvuk", + "noAudioDetections": "Žádné detekce zvuku", + "score": "skóre", + "currentRMS": "Aktuální RMS", + "currentdbFS": "Aktuální dbFS" + }, + "paths": { + "title": "Cesty", + "desc": "Zobrazit významné body trasy sledovaného objektu", + "tips": "Cesty
Čáry a kruhy označují významné body, kterými se sledovaný objekt během svého životního cyklu pohyboval.
" } }, "camera": { @@ -444,7 +470,44 @@ }, "limitDetections": "Omezit detekce pro specifické zóny" }, - "title": "Nastavení Kamery" + "title": "Nastavení Kamery", + "object_descriptions": { + "title": "AI generované popisy objektů", + "desc": "Dočasně povolit/zakázat generativní popisy objektů AI pro tuto kameru. Pokud je tato funkce zakázána, nebudou pro sledované objekty na této kameře vyžadovány popisy generované AI." + }, + "review_descriptions": { + "title": "Popisy generativní AI", + "desc": "Dočasně povolit/zakázat generativní AI recenze popisů pro tuto kameru. Pokud je tato funkce zakázána, nebudou pro položky recenzí na této kameře vyžadovány popisy generované AI." + }, + "addCamera": "Přidat novou kameru", + "editCamera": "Upravit kameru:", + "selectCamera": "Vybrat kameru", + "backToSettings": "Zpět k nastavení kamery", + "cameraConfig": { + "add": "Přidat kameru", + "edit": "Upravit kameru", + "description": "Konfigurovat nastavení kamery, včetně vstupů streamu a rolí.", + "name": "Název kamery", + "nameRequired": "Název kamery je povinný", + "nameLength": "Název kamery musí mít méně než 24 znaků.", + "namePlaceholder": "např. přední dveře", + "enabled": "Povolit", + "ffmpeg": { + "inputs": "Vstupní streamy", + "path": "Cesta streamu", + "pathRequired": "Cesta ke streamu je povinná", + "pathPlaceholder": "rtsp://...", + "roles": "Role", + "rolesRequired": "Je vyžadována alespoň jedna role", + "rolesUnique": "Každá role (audio, detekce, záznam) může být přiřazena pouze k jednomu streamu", + "addInput": "Přidat vstupní stream", + "removeInput": "Odebrat vstupní stream", + "inputsRequired": "Je vyžadován alespoň jeden vstupní stream" + }, + "toast": { + "success": "Kamera {{cameraName}} byla úspěšně uložena" + } + } }, "notification": { "notificationSettings": { @@ -469,7 +532,7 @@ "desc": "Je vyžadována platná e-mailová adresa, která bude použita k upozornění v případě problémů se službou push notifikací." }, "registerDevice": "Registrovat Toto Zařízení", - "deviceSpecific": "Nastavení Specifická pro Zařízení", + "deviceSpecific": "Nastavení specifická pro zařízení", "unregisterDevice": "Odregistrovat Toto Zařízení", "sendTestNotification": "Poslat testovací notifikaci", "unsavedRegistrations": "Neuložené přihlášky k Notifikacím", @@ -553,7 +616,8 @@ "admin": "Správce", "adminDesc": "Plný přístup ke všem funkcím.", "viewer": "Divák", - "viewerDesc": "Omezení pouze na Živé dashboardy, Revize, Průzkumníka a Exporty." + "viewerDesc": "Omezení pouze na Živé dashboardy, Revize, Průzkumníka a Exporty.", + "customDesc": "Vlastní role s konkrétním přístupem ke kameře." }, "title": "Změnit Roli Uživatele", "desc": "Aktualizovat oprávnění pro {{username}}", @@ -572,11 +636,11 @@ "actions": "Akce", "noUsers": "Žádní uživatelé nebyli nalezeni.", "changeRole": "Změnit roli uživatele", - "password": "Heslo", + "password": "Resetovat Heslo", "deleteUser": "Smazat uživatele", "role": "Role" }, - "updatePassword": "Aktualizovat heslo", + "updatePassword": "Resetovat heslo", "toast": { "success": { "createUser": "Uživatel {{user}} úspěšně vytvořen", @@ -593,13 +657,13 @@ }, "management": { "desc": "Spravujte uživatelské účty této instance Frigate.", - "title": "Správa Uživatelů" + "title": "Správa uživatelů" }, "addUser": "Přidat uživatele", "title": "Uživatelé" }, "motionDetectionTuner": { - "unsavedChanges": "Neuložené změny Ladiče Detekce Pohybu {{camera}}", + "unsavedChanges": "Neuložené změny ladění detekce pohybu {{camera}}", "improveContrast": { "title": "Zlepšit Kontrast", "desc": "Zlepšit kontrast pro tmavé scény Výchozí: ON" @@ -607,9 +671,9 @@ "toast": { "success": "Nastavení detekce pohybu bylo uloženo." }, - "title": "Ladič Detekce Pohybu", + "title": "Ladění detekce pohybu", "desc": { - "documentation": "Přečtěte si příručku Ladiče Detekce Pohybu", + "documentation": "Přečtěte si příručku Ladění detekce pohybu", "title": "Frigate používá detekci pohybu jako první kontrolu k ověření, zda se ve snímku děje něco, co stojí za další analýzu pomocí detekce objektů." }, "Threshold": { @@ -624,7 +688,7 @@ "enrichments": { "title": "Nastavení obohacení", "faceRecognition": { - "title": "Rozpoznání Obličeje", + "title": "Rozpoznání obličeje", "desc": "Rozpoznávání obličeje umožňuje přiřadit lidem jména a po rozpoznání jejich obličeje. Frigate přiřadí jméno osoby jako podštítek. Tyto informace jsou zahrnuty v uživatelském rozhraní, filtrech a také v oznámeních.", "readTheDocumentation": "Přečtěte si Dokumentaci", "modelSize": { @@ -651,11 +715,11 @@ "alreadyInProgress": "Přeindexování je již spuštěno.", "error": "Chyba spuštění přeindexování: {{errorMessage}}" }, - "title": "Sémantické Vyhledávání", + "title": "Sémantické vyhledávání", "desc": "Sémantické vyhledávání ve Frigate umožňuje najít sledované objekty v rámci vašich zkontrolovaných položek pomocí samotného obrázku, uživatelem definovaného textového popisu nebo automaticky generovaného popisu.", "readTheDocumentation": "Přečtěte si Dokumentaci", "modelSize": { - "label": "Velikost Modelu", + "label": "Velikost modelu", "desc": "Velikost modelu použitého pro vkládání sémantického vyhledávání.", "small": { "title": "malý", @@ -669,7 +733,7 @@ }, "birdClassification": { "desc": "Klasifikace ptáků identifikuje známé ptáky pomocí kvantovaného modelu Tensorflow. Po rozpoznání známého ptáka se jeho běžný název přidá jako sub_label. Tato informace je zahrnuta v uživatelském rozhraní, filtrech a také v oznámeních.", - "title": "Klasifikace Ptáků" + "title": "Klasifikace ptáků" }, "unsavedChanges": "Neuložené změny nastavení Obohacení", "licensePlateRecognition": { @@ -682,5 +746,193 @@ "success": "Nastavení Obohacení uloženo. Restartujte Frigate aby se změny aplikovaly.", "error": "Chyba ukládání změn konfigurace: {{errorMessage}}" } + }, + "triggers": { + "documentTitle": "Spouštěče", + "management": { + "title": "Spouštěče", + "desc": "Spravovat spouštěče pro {{camera}}. Použít typ miniatury ke spuštění u miniatur podobných vybranému sledovanému objektu a typ popisu ke spuštění u popisů podobných zadanému textu." + }, + "addTrigger": "Přidat spouštěč", + "table": { + "name": "Jméno", + "type": "Typ", + "content": "Obsah", + "threshold": "Prahová hodnota", + "actions": "Akce", + "noTriggers": "Pro tuto kameru nejsou nakonfigurovány žádné spouštěče.", + "edit": "Upravit", + "deleteTrigger": "Smazat spouštěč", + "lastTriggered": "Naposledy spuštěno" + }, + "type": { + "thumbnail": "Miniatura", + "description": "Popis" + }, + "actions": { + "alert": "Označit jako upozornění", + "notification": "Odeslat oznámení" + }, + "dialog": { + "createTrigger": { + "title": "Vytvořit spouštěč", + "desc": "Vytvořit spouštěč pro kameru {{camera}}" + }, + "editTrigger": { + "title": "Upravit spouštěč", + "desc": "Upravit nastavení spouštěče na kameře {{camera}}" + }, + "deleteTrigger": { + "title": "Odstranit spouštěč", + "desc": "Opravdu chcete odstranit spouštěč {{triggerName}}? Tuto akci nelze vrátit zpět." + }, + "form": { + "name": { + "title": "Název", + "placeholder": "Pojmenujte tento spouštěč", + "error": { + "minLength": "Pole musí mít alespoň 2 znaky.", + "invalidCharacters": "Pole může obsahovat pouze písmena, číslice, podtržítka a pomlčky.", + "alreadyExists": "Spouštěč s tímto názvem již pro tuto kameru existuje." + } + }, + "enabled": { + "description": "Povolit nebo zakázat tento spouštěč" + }, + "type": { + "title": "Typ", + "placeholder": "Vybrat typ spouštěče" + }, + "content": { + "title": "Obsah", + "imagePlaceholder": "Vyberte miniaturu", + "textPlaceholder": "Zadat textový obsah", + "imageDesc": "Je zobrazeno pouze posledních 100 miniatur. Pokud nemůžete najít požadovanou miniaturu, prosím zkontrolujte dřívější objekty v Prozkoumat a nastavte spouštěč ze tamějšího menu.", + "textDesc": "Zadejte text, který spustí tuto akci, když bude zjištěn podobný popis sledovaného objektu.", + "error": { + "required": "Obsah je povinný." + } + }, + "actions": { + "title": "Akce", + "desc": "Ve výchozím nastavení Frigate odesílá MQTT zprávu pro všechny spouštěče. Podřazené popisky přidávají název spouštěče k popisku objektu. Atributy jsou prohledávatelná metadata uložená samostatně v metadatech sledovaného objektu.", + "error": { + "min": "Musí být vybrána alespoň jedna akce." + } + }, + "threshold": { + "title": "Práh", + "error": { + "min": "Práh musí být alespoň 0", + "max": "Práh musí být nanejvýš 1" + } + } + } + }, + "toast": { + "success": { + "createTrigger": "Spouštěč {{name}} byl úspěšně vytvořen.", + "updateTrigger": "Spouštěč {{name}} byl úspěšně aktualizován.", + "deleteTrigger": "Spouštěč {{name}} byl úspěšně smazán." + }, + "error": { + "createTriggerFailed": "Nepodařilo se vytvořit spouštěč: {{errorMessage}}", + "updateTriggerFailed": "Nepodařilo se aktualizovat spouštěč: {{errorMessage}}", + "deleteTriggerFailed": "Nepodařilo se smazat spouštěč: {{errorMessage}}" + } + } + }, + "roles": { + "addRole": "Přidat roli", + "table": { + "role": "Role", + "cameras": "Kamery", + "actions": "Akce", + "noRoles": "Nebyly nalezeny žádné vlastní role.", + "editCameras": "Upravit kamery", + "deleteRole": "Smazat roli" + }, + "toast": { + "success": { + "createRole": "Role {{role}} byla úspěšně vytvořena", + "updateCameras": "Kamery byly aktualizovány pro roli {{role}}", + "deleteRole": "Role {{role}} byla úspěšně smazána", + "userRolesUpdated_one": "{{count}} uživatel přiřazený k této roli byl aktualizován na „diváka“, který má přístup ke všem kamerám.", + "userRolesUpdated_few": "{{count}} uživatelé přiřazení k této roli bylo aktualizováno na „diváky“, kteří mají přístup ke všem kamerám.", + "userRolesUpdated_other": "{{count}} uživatelů přiřazených k této roli bylo aktualizováno na „diváky“, kteří mají přístup ke všem kamerám." + }, + "error": { + "createRoleFailed": "Nepodařilo se vytvořit roli: {{errorMessage}}", + "updateCamerasFailed": "Nepodařilo se aktualizovat kamery: {{errorMessage}}", + "deleteRoleFailed": "Nepodařilo se smazat roli: {{errorMessage}}", + "userUpdateFailed": "Nepodařilo se aktualizovat role uživatele: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Vytvořit novou roli", + "desc": "Přidejte novou roli a určete oprávnění k přístupu ke kamerám." + }, + "deleteRole": { + "title": "Smazat roli", + "warn": "Opravdu chcete smazat roli {{role}}?", + "deleting": "Mazání...", + "desc": "Tuto akci nelze vrátit zpět. Role bude trvale smazána a všichni uživatelé s touto rolí budou přeřazeni do role „Divák“, která poskytne přístup ke všem kamerám." + }, + "form": { + "role": { + "title": "Název role", + "placeholder": "Zadejte název role", + "desc": "Povolena jsou pouze písmena, čísla, tečky a podtržítka.", + "roleIsRequired": "Název role je povinný", + "roleOnlyInclude": "Název role smí obsahovat pouze písmena, čísla, . nebo _", + "roleExists": "Role s tímto názvem již existuje." + }, + "cameras": { + "title": "Kamery", + "desc": "Vyberte kamery, ke kterým má tato role přístup. Je vyžadována alespoň jedna kamera.", + "required": "Musí být vybrána alespoň jedna kamera." + } + }, + "editCameras": { + "desc": "Aktualizujte přístup ke kamerám pro roli {{role}}.", + "title": "Upravit kamery role" + } + }, + "management": { + "title": "Správa role diváka", + "desc": "Spravujte vlastní role diváků a jejich oprávnění k přístupu ke kamerám pro tuto instanci Frigate." + } + }, + "cameraWizard": { + "save": { + "success": "Nová kamera {{cameraName}} úspěšně uložena." + }, + "step2": { + "testSuccess": "Test připojení v pořádku!", + "probeSuccessful": "Sonda úspěšná", + "probeNoSuccess": "Sonda neúspěšná" + }, + "step3": { + "testSuccess": "Test streamu v pořádku!" + }, + "step4": { + "reconnectionSuccess": "Opakované připojení úspěšné.", + "streamValidated": "Stream {{number}} úspěšně ověřený" + } + }, + "cameraManagement": { + "cameraConfig": { + "toast": { + "success": "Kamera {{cameraName}} úspěšně uložena" + } + } + }, + "cameraReview": { + "reviewClassification": { + "toast": { + "success": "Konfigurace Klasifikací Revizí byla uložena. Restartujte Frigate pro aplikování změn." + } + } } } diff --git a/web/public/locales/cs/views/system.json b/web/public/locales/cs/views/system.json index fca20986f..b2aa71aaf 100644 --- a/web/public/locales/cs/views/system.json +++ b/web/public/locales/cs/views/system.json @@ -52,7 +52,8 @@ "detectIsSlow": "{{detect}} je pomalé ({{speed}} ms)", "detectIsVerySlow": "{{detect}} je velmi pomalé ({{speed}} ms)", "detectHighCpuUsage": "{{camera}} má vysoké využití CPU detekcemi ({{detectAvg}} %)", - "ffmpegHighCpuUsage": "{{camera}} má vyské využití CPU FFmpegem ({{ffmpegAvg}}%)" + "ffmpegHighCpuUsage": "{{camera}} má vyské využití CPU FFmpegem ({{ffmpegAvg}}%)", + "shmTooLow": "Alokace /dev/shm ({{total}} MB) by měla být zvýšena alespoň na {{min}} MB." }, "enrichments": { "embeddings": { @@ -77,7 +78,8 @@ "title": "Detektory", "inferenceSpeed": "Detekční rychlost", "memoryUsage": "Detektor využití paměti", - "cpuUsage": "Detektor využití CPU" + "cpuUsage": "Detektor využití CPU", + "cpuUsageInformation": "CPU používané při přípravě vstupních a výstupních dat do/z detekčních modelů. Tato hodnota neměří využití inferenčních operací, ani v případě použití GPU nebo akcelerátoru." }, "hardwareInfo": { "title": "Informace o hardware", @@ -110,12 +112,23 @@ "gpuUsage": "Využití CPU", "gpuMemory": "Paměť GPU", "gpuEncoder": "GPU kodér", - "gpuDecoder": "GPU Dekodér" + "gpuDecoder": "GPU Dekodér", + "intelGpuWarning": { + "title": "Upozornění Intel GPU Stats", + "message": "Statistiky GPU nedostupné", + "description": "Toto je známá chyba v nástrojích Intel pro hlášení statistik GPU (intel_gpu_top), která selhává a opakovaně vrací využití GPU 0 %, a to i v případech, kdy na (i)GPU správně běží hardwarová akcelerace a detekce objektů. Nejedná se o chybu Frigate. Můžete restartovat hostitele, abyste problém dočasně vyřešili a potvrdili, že GPU funguje správně. Toto neovlivňuje výkon." + } }, "otherProcesses": { "title": "Ostatní procesy", "processCpuUsage": "Využití CPU procesy", - "processMemoryUsage": "Využití paměti procesy" + "processMemoryUsage": "Využití paměti procesy", + "series": { + "go2rtc": "go2rtc", + "recording": "nahrávání", + "review_segment": "revidovat segment", + "embeddings": "vložení" + } }, "title": "Hlavní" }, @@ -138,7 +151,11 @@ "tips": "Tato hodnota uvádí celkové využití disku záznamy uloženými v databázi Frigate. Frigate nesleduje využití disku ostatními soubory na vašem disku." }, "title": "Úložiště", - "overview": "Přehled" + "overview": "Přehled", + "shm": { + "title": "přiřazení SHM (sdílené paměti)", + "warning": "Nynější velikost SHM činící {{total}}MB je příliš malá. Zvyšte ji alespoň na {{min_shm}}MB." + } }, "lastRefreshed": "Poslední aktualizace: ", "documentTitle": { diff --git a/web/public/locales/da/audio.json b/web/public/locales/da/audio.json index 0967ef424..168ef4c67 100644 --- a/web/public/locales/da/audio.json +++ b/web/public/locales/da/audio.json @@ -1 +1,199 @@ -{} +{ + "clip_clop": "Klepanie kopyt", + "neigh": "Revanie", + "cattle": "Hovädzí dobytok", + "moo": "Bučanie", + "cowbell": "Kravský zvonec", + "pig": "Prasa", + "speech": "Tale", + "bicycle": "Cykel", + "car": "Bil", + "bellow": "Under", + "motorcycle": "Motorcykel", + "whispering": "Hvisker", + "bus": "Bus", + "laughter": "Latter", + "train": "Tog", + "boat": "Båd", + "crying": "Græder", + "tambourine": "Tambourin", + "marimba": "Marimba", + "trumpet": "Trumpet", + "trombone": "Trombone", + "violin": "Violin", + "flute": "Fløjte", + "saxophone": "Saxofon", + "clarinet": "Klarinet", + "harp": "Harpe", + "bell": "Klokke", + "harmonica": "Harmonika", + "bagpipes": "Sækkepiber", + "didgeridoo": "Didgeridoo", + "jazz": "Jazz", + "opera": "Opera", + "dubstep": "Dubstep", + "blues": "Blues", + "song": "Sang", + "lullaby": "Vuggevise", + "wind": "Vind", + "thunderstorm": "Tordenvejr", + "thunder": "Torden", + "water": "Vand", + "rain": "Regn", + "raindrop": "Regndråbe", + "waterfall": "Vandfald", + "waves": "Bølger", + "fire": "Ild", + "vehicle": "Køretøj", + "sailboat": "Sejlbåd", + "rowboat": "Robåd", + "motorboat": "Motorbåd", + "ship": "Skib", + "ambulance": "Ambulance", + "helicopter": "Helikopter", + "skateboard": "Skateboard", + "chainsaw": "Motorsav", + "door": "Dør", + "doorbell": "Dørklokke", + "slam": "Smæk", + "knock": "Bank", + "squeak": "Knirke", + "dishes": "Tallerkener", + "cutlery": "Bestik", + "sink": "Håndvask", + "bathtub": "Badekar", + "toothbrush": "Tandbørste", + "zipper": "Lynlås", + "coin": "Mønt", + "scissors": "Saks", + "typewriter": "Skrivemaskine", + "alarm": "Alarm", + "telephone": "Telefon", + "ringtone": "Ringetone", + "siren": "Sirene", + "foghorn": "Tågehorn", + "whistle": "Fløjte", + "clock": "Ur", + "printer": "Printer", + "camera": "Kamera", + "tools": "Værktøj", + "hammer": "Hammer", + "drill": "Boremaskine", + "explosion": "Eksplosion", + "fireworks": "Nytårskrudt", + "babbling": "Pludren", + "yell": "Råb", + "whoop": "Jubel", + "snicker": "Smålatter", + "bird": "Fugl", + "cat": "Kat", + "dog": "Hund", + "horse": "Hest", + "sheep": "Får", + "mouse": "Mus", + "keyboard": "Tastatur", + "blender": "Mixer", + "hair_dryer": "Føntørrer", + "animal": "Dyr", + "bark": "Gø", + "goat": "Gæd", + "sigh": "Suk", + "singing": "Synger", + "choir": "Kor", + "yodeling": "Jodlen", + "chant": "Messe", + "mantra": "Meditationsmantra", + "child_singing": "Barn Synger", + "synthetic_singing": "Syntetisk Sang", + "rapping": "Rapper", + "humming": "Nynner", + "groan": "Støn", + "grunt": "Grynt", + "whistling": "Fløjter", + "breathing": "Vejrtrækning", + "wheeze": "Hæsende vejrtrækning", + "snoring": "Snorker", + "gasp": "Gisp", + "pant": "Anstrengende vejrtrækning", + "snort": "Fnyse", + "cough": "Hoster", + "throat_clearing": "Rømmer sig", + "sneeze": "Nyser", + "sniff": "Snøfter", + "run": "Løb", + "shuffle": "Trække fødderne", + "footsteps": "Fodtrin", + "chewing": "Tygger", + "biting": "Bider", + "gargling": "Gurgler", + "stomach_rumble": "Maverumlen", + "burping": "Bøvser", + "hiccup": "Hikke", + "fart": "Prut", + "hands": "Hænder", + "finger_snapping": "Knipse fingere", + "clapping": "Klapper", + "heartbeat": "Hjertebanken", + "heart_murmur": "Hjertemislyd", + "cheering": "Hujen", + "applause": "Bifald", + "chatter": "Snak", + "crowd": "Forsamling", + "children_playing": "Børn leger", + "pets": "Kæledyr", + "yip": "Jubel", + "howl": "Hyl", + "bow_wow": "Vov vov", + "growling": "Knurren", + "whimper_dog": "Hundeklynk", + "purr": "Spinde", + "meow": "Meaw", + "hiss": "Hvæser", + "caterwaul": "Kattejammer", + "livestock": "Husdyr", + "oink": "Nøf", + "bleat": "Brægen", + "vibration": "Vibration", + "fowl": "Fjerkræ", + "chicken": "Kylling", + "cluck": "Kagle", + "cock_a_doodle_doo": "Kykeliky", + "turkey": "Kalkun", + "gobble": "Kalkunlyd", + "duck": "And", + "quack": "Rap", + "goose": "Gås", + "honk": "Dyt", + "wild_animals": "Vilde dyr", + "roaring_cats": "Brølende katte", + "roar": "Brøl", + "chirp": "Pip", + "squawk": "Skræppen", + "pigeon": "Due", + "coo": "Kurre", + "crow": "Krage", + "caw": "Kragelyd", + "owl": "Ugle", + "hoot": "Uglehyl", + "flapping_wings": "Vingeslag", + "dogs": "Hunde", + "rats": "Rotter", + "patter": "Dråbelyd", + "insect": "Insekt", + "cricket": "Cricket", + "guitar": "Guitar", + "electric_guitar": "Elektrisk Guitar", + "bass_guitar": "Basguitar", + "acoustic_guitar": "Akustisk Guitar", + "steel_guitar": "Stål Guitar", + "tapping": "Tapping på guitar", + "strum": "Slå an", + "banjo": "Banjo", + "sitar": "Sitar", + "mandolin": "Mandolin", + "snare_drum": "Lilletromme", + "rimshot": "Kantslag", + "drum_roll": "Trommehvirvel", + "bass_drum": "Stortromme", + "techno": "Techno" +} diff --git a/web/public/locales/da/common.json b/web/public/locales/da/common.json index b0bbd3d5f..62b6d7036 100644 --- a/web/public/locales/da/common.json +++ b/web/public/locales/da/common.json @@ -1,6 +1,6 @@ { "time": { - "untilForTime": "Indtil{{time}}", + "untilForTime": "Indtil {{time}}", "untilForRestart": "Indtil Frigate genstarter.", "untilRestart": "Indtil genstart", "ago": "{{timeAgo}} siden", @@ -24,13 +24,13 @@ "am": "am", "year_one": "{{time}} år", "year_other": "{{time}} år", - "mo": "{{time}}mo", + "mo": "{{time}}må", "month_one": "{{time}} måned", "month_other": "{{time}} måneder", "d": "{{time}}d", "day_one": "{{time}} dag", "day_other": "{{time}} dage", - "h": "{{time}}h", + "h": "{{time}}t", "yr": "{{time}}yr", "hour_one": "{{time}} time", "hour_other": "{{time}} timer", @@ -41,11 +41,11 @@ "second_one": "{{time}} sekund", "second_other": "{{time}} sekunder", "formattedTimestamp": { - "12hour": "MMM d, h:mm:ss aaa", - "24hour": "MMM d, HH:mm:ss" + "12hour": "d MMM, h:mm:ss aaa", + "24hour": "d. MMM, HH:mm:ss" }, "formattedTimestamp2": { - "12hour": "MM/dd h:mm:ssa", + "12hour": "dd/MM h:mm:ss", "24hour": "d MMM HH:mm:ss" }, "formattedTimestampHourMinute": { @@ -57,22 +57,26 @@ "24hour": "HH:mm:ss" }, "formattedTimestampMonthDayHourMinute": { - "12hour": "MMM d, h:mm aaa", - "24hour": "MMM d, HH:mm" + "12hour": "d MMM, h:mm aaa", + "24hour": "d MMM, HH:mm" }, "formattedTimestampMonthDayYear": { - "12hour": "MMM d, yyyy", - "24hour": "MMM d, yyyy" + "12hour": "d MMM, yyyy", + "24hour": "d MMM, yyyy" }, "formattedTimestampMonthDayYearHourMinute": { - "12hour": "MMM d yyyy, h:mm aaa", - "24hour": "MMM d yyyy, HH:mm" + "12hour": "d MMM yyyy, h:mm aaa", + "24hour": "d MMM yyyy, HH:mm" }, - "formattedTimestampMonthDay": "MMM d", + "formattedTimestampMonthDay": "d MMM", "formattedTimestampFilename": { - "12hour": "MM-dd-yy-h-mm-ss-a", - "24hour": "MM-dd-yy-HH-mm-ss" - } + "12hour": "dd-MM-yy-h-mm-ss-a", + "24hour": "dd-MM-yy-HH-mm-ss" + }, + "never": "Aldrig", + "inProgress": "Under behandling", + "invalidStartTime": "Ugyldig starttid", + "invalidEndTime": "Ugyldig sluttid" }, "unit": { "speed": { @@ -82,14 +86,28 @@ "length": { "feet": "fod", "meters": "meter" + }, + "data": { + "kbps": "kB/s", + "mbps": "MB/s", + "gbps": "GB/s", + "kbph": "kB/time", + "mbph": "MB/time", + "gbph": "GB/time" } }, "label": { - "back": "Gå tilbage" + "back": "Gå tilbage", + "hide": "Skjul {{item}}", + "show": "Vis {{item}}", + "ID": "ID", + "none": "Ingen", + "all": "Alle", + "other": "Andet" }, "button": { "apply": "Anvend", - "reset": "Reset", + "reset": "Nulstil", "done": "Udført", "enabled": "Aktiveret", "enable": "Aktiver", @@ -116,21 +134,22 @@ "no": "Nej", "download": "Download", "info": "Info", - "suspended": "Suspenderet", - "unsuspended": "Ophæv suspendering", + "suspended": "Sat på pause", + "unsuspended": "Genoptag", "play": "Afspil", "unselect": "Fravælg", "export": "Eksporter", "deleteNow": "Slet nu", - "next": "Næste" + "next": "Næste", + "continue": "Fortsæt" }, "menu": { "system": "System", - "systemMetrics": "System metrics", + "systemMetrics": "Systemstatistik", "configuration": "Konfiguration", - "systemLogs": "System logs", + "systemLogs": "Systemlogfiler", "settings": "Indstillinger", - "configurationEditor": "Konfiguratons Editor", + "configurationEditor": "Konfigurationsværktøj", "languages": "Sprog", "language": { "en": "English (Engelsk)", @@ -165,8 +184,17 @@ "th": "ไทย (Thai)", "ca": "Català (Katalansk)", "withSystem": { - "label": "Brug system indstillinger for sprog" - } + "label": "Brug systemindstillinger for sprog" + }, + "ptBR": "Português brasileiro (Brasiliansk Portugisisk)", + "sr": "Српски (Serbisk)", + "sl": "Slovenščina (Slovensk)", + "lt": "Lietuvių (Litauisk)", + "bg": "Български (Bulgarsk)", + "gl": "Galego (Galisisk)", + "id": "Bahasa Indonesia (Indonesisk)", + "ur": "اردو (Urdu)", + "hr": "Hrvatski (Kroatisk)" }, "appearance": "Udseende", "darkMode": { @@ -185,7 +213,7 @@ "nord": "Nord", "red": "Rød", "highcontrast": "Høj Kontrast", - "default": "Default" + "default": "Standard" }, "help": "Hjælp", "documentation": { @@ -194,7 +222,7 @@ }, "restart": "Genstart Frigate", "live": { - "title": "Live", + "title": "Direkte", "allCameras": "Alle kameraer", "cameras": { "title": "Kameraer", @@ -202,27 +230,28 @@ "count_other": "{{count}} Kameraer" } }, - "review": "Review", + "review": "Gennemse", "explore": "Udforsk", "export": "Eksporter", "uiPlayground": "UI sandkasse", - "faceLibrary": "Face Library", + "faceLibrary": "Ansigtsarkiv", "user": { "title": "Bruger", "account": "Konto", "current": "Aktiv bruger: {{user}}", "anonymous": "anonym", - "logout": "Logout", - "setPassword": "Set Password" - } + "logout": "Log ud", + "setPassword": "Vælg kodeord" + }, + "classification": "Kategorisering" }, "toast": { - "copyUrlToClipboard": "Kopieret URL til klippebord.", + "copyUrlToClipboard": "Kopieret URL til udklipsholder.", "save": { "title": "Gem", "error": { - "title": "Ændringer kan ikke gemmes: {{errorMessage}}", - "noMessage": "Kan ikke gemme konfigurationsændringer" + "title": "Ændringer kunne ikke gemmes: {{errorMessage}}", + "noMessage": "Kunne ikke gemme konfigurationsændringer" } } }, @@ -233,7 +262,7 @@ "desc": "Admins har fuld adgang til Frigate UI. Viewers er begrænset til at se kameraer, gennemse items, og historik i UI." }, "pagination": { - "label": "paginering", + "label": "sideinddeling", "previous": { "title": "Forrige", "label": "Gå til forrige side" @@ -245,14 +274,27 @@ "more": "Flere sider" }, "accessDenied": { - "documentTitle": "Adgang forbudt - Frigate", - "title": "Adgang forbudt", - "desc": "Du har ikke tiiladelse til at se denne side." + "documentTitle": "Adgang nægtet - Frigate", + "title": "Adgang nægtet", + "desc": "Du har ikke rettigheder til at se denne side." }, "notFound": { "documentTitle": "Ikke fundet - Frigate", "title": "404", - "desc": "Side ikke fundet" + "desc": "Siden blev ikke fundet" }, - "selectItem": "Vælg {{item}}" + "selectItem": "Vælg {{item}}", + "readTheDocumentation": "Læs dokumentationen", + "list": { + "two": "{{0}} og {{1}}", + "many": "{{items}}, og {{last}}", + "separatorWithSpace": ", " + }, + "field": { + "optional": "Valgfrit", + "internalID": "Det interne ID som Frigate bruger i konfigurationen og databasen" + }, + "information": { + "pixels": "{{area}}px" + } } diff --git a/web/public/locales/da/components/auth.json b/web/public/locales/da/components/auth.json index 0967ef424..9df944d4c 100644 --- a/web/public/locales/da/components/auth.json +++ b/web/public/locales/da/components/auth.json @@ -1 +1,16 @@ -{} +{ + "form": { + "user": "Brugernavn", + "password": "Kodeord", + "login": "Log ind", + "errors": { + "usernameRequired": "Brugernavn kræves", + "passwordRequired": "Kodeord kræves", + "loginFailed": "Login fejlede", + "unknownError": "Ukendt fejl. Tjek logs.", + "rateLimit": "Grænsen for forespørgsler er overskredet. Prøv igen senere.", + "webUnknownError": "Ukendt fejl. Tjek konsollogs." + }, + "firstTimeLogin": "Forsøger du at logge ind for første gang? Loginoplysningerne står i Frigate-loggene." + } +} diff --git a/web/public/locales/da/components/camera.json b/web/public/locales/da/components/camera.json index 0967ef424..cc5244b8a 100644 --- a/web/public/locales/da/components/camera.json +++ b/web/public/locales/da/components/camera.json @@ -1 +1,86 @@ -{} +{ + "group": { + "label": "Kamera Grupper", + "add": "Tilføj Kameragruppe", + "edit": "Rediger Kamera Gruppe", + "delete": { + "label": "Slet kamera gruppe", + "confirm": { + "title": "Bekræft sletning", + "desc": "Er du sikker på at du vil slette kamera gruppen {{name}}?" + } + }, + "name": { + "label": "Navn", + "placeholder": "Indtast et navn…", + "errorMessage": { + "mustLeastCharacters": "Kameragruppens navn skal være mindst 2 tegn.", + "exists": "Kameragruppenavn findes allerede.", + "nameMustNotPeriod": "Kameragruppenavn må ikke indeholde en periode.", + "invalid": "Ugyldigt kamera gruppenavn." + } + }, + "cameras": { + "label": "Kameraer", + "desc": "Vælg kameraer til denne gruppe." + }, + "icon": "Ikon", + "success": "Kameragruppe ({{name}}) er blevet gemt.", + "camera": { + "birdseye": "Fugleøje", + "setting": { + "label": "Kamera Streaming Indstillinger", + "title": "{{cameraName}} Streaming Indstillinger", + "desc": "Skift de live streaming muligheder for denne kameragruppes dashboard. Disse indstillinger er enheds- og browserspecifikke.", + "audioIsAvailable": "Lyd er tilgængelig for denne stream", + "audioIsUnavailable": "Lyd er ikke tilgængelig for denne strøm", + "audio": { + "tips": { + "title": "Lyd skal komme fra dit kamera og konfigureret i go2rtc til denne stream." + } + }, + "stream": "Stream", + "placeholder": "Vælg en stream", + "streamMethod": { + "label": "Streaming Metode", + "placeholder": "Vælg en streaming metode", + "method": { + "noStreaming": { + "label": "Ingen Streaming", + "desc": "Kamerabilleder vil kun opdatere én gang i minuttet og ingen live streaming vil forekomme." + }, + "smartStreaming": { + "label": "Smart Streaming (anbefalet)", + "desc": "Smart streaming vil opdatere dit kamerabillede én gang i minuttet, når der ikke sker noget, for at spare båndbredde og ressourcer. Når der registreres aktivitet, skifter billedet problemfrit til en live stream." + }, + "continuousStreaming": { + "label": "Kontinuerlig Streaming", + "desc": { + "title": "Kamerabillede vil altid være en live stream, når det er synligt på instrumentbrættet, selv om der ikke registreres nogen aktivitet.", + "warning": "Kontinuerlig streaming kan forårsage højt båndbreddeforbrug og ydelsesproblemer. Brug med omtanke." + } + } + } + }, + "compatibilityMode": { + "label": "Kompatibilitetstilstand", + "desc": "Aktivér kun denne mulighed, hvis kameraets live stream viser farve artefakter og har en diagonal linje på højre side af billedet." + } + } + } + }, + "debug": { + "options": { + "label": "Indstillinger", + "title": "Valgmuligheder", + "showOptions": "Vis muligheder", + "hideOptions": "Skjul muligheder" + }, + "boundingBox": "Afgrænsningsfelt", + "timestamp": "Tidsstempel", + "zones": "Zoner", + "mask": "Maske", + "motion": "Bevægelse", + "regions": "Regioner" + } +} diff --git a/web/public/locales/da/components/dialog.json b/web/public/locales/da/components/dialog.json index 0967ef424..4d4a85174 100644 --- a/web/public/locales/da/components/dialog.json +++ b/web/public/locales/da/components/dialog.json @@ -1 +1,25 @@ -{} +{ + "restart": { + "title": "Er du sikker på at du vil genstarte Frigate?", + "button": "Genstart", + "restarting": { + "title": "Frigate genstarter", + "button": "Gennemtving genindlæsning nu", + "content": "Denne side genindlæses om {{countdown}} sekunder." + } + }, + "explore": { + "plus": { + "submitToPlus": { + "label": "Indsend til Frigate+", + "desc": "Objekter på steder, du ønsker at undgå, er ikke falske positiver. Hvis du indsender dem som falske positiver, vil det forvirre modellen." + }, + "review": { + "question": { + "label": "Bekræft denne etiket til Frigate Plus", + "ask_a": "Er dette objekt et{{label}}?"
+ }
+ }
+ }
+ }
+}
diff --git a/web/public/locales/da/components/filter.json b/web/public/locales/da/components/filter.json
index 0967ef424..3d16c1eb1 100644
--- a/web/public/locales/da/components/filter.json
+++ b/web/public/locales/da/components/filter.json
@@ -1 +1,50 @@
-{}
+{
+ "filter": "Filter",
+ "classes": {
+ "label": "Klasser",
+ "all": {
+ "title": "Alle klasser"
+ },
+ "count_one": "{{count}} Klasse",
+ "count_other": "{{count}} Klasser"
+ },
+ "labels": {
+ "all": {
+ "short": "Labels",
+ "title": "Alle etiketter"
+ },
+ "count_one": "{{count}} Label",
+ "label": "Etiketter"
+ },
+ "zones": {
+ "label": "Zoner",
+ "all": {
+ "title": "Alle zoner",
+ "short": "Zoner"
+ }
+ },
+ "more": "Flere filtre",
+ "sort": {
+ "label": "Sortér",
+ "dateAsc": "Dato (Stigende)",
+ "dateDesc": "Dato (Faldende)",
+ "speedAsc": "Anslået hastighed (Stigende)",
+ "speedDesc": "Anslået hastighed (Faldende)",
+ "relevance": "Relevans"
+ },
+ "dates": {
+ "selectPreset": "Vælg en forudindstilling…",
+ "all": {
+ "title": "Alle datoer",
+ "short": "Datoer"
+ }
+ },
+ "reset": {
+ "label": "Nulstille filtre til standardværdier"
+ },
+ "timeRange": "Tidsinterval",
+ "estimatedSpeed": "Anslået hastighed ({{unit}})",
+ "features": {
+ "hasVideoClip": "Har et videoklip"
+ }
+}
diff --git a/web/public/locales/da/components/icons.json b/web/public/locales/da/components/icons.json
index 0967ef424..5d7e37407 100644
--- a/web/public/locales/da/components/icons.json
+++ b/web/public/locales/da/components/icons.json
@@ -1 +1,8 @@
-{}
+{
+ "iconPicker": {
+ "selectIcon": "Vælg et ikon",
+ "search": {
+ "placeholder": "Søg efter et ikon…"
+ }
+ }
+}
diff --git a/web/public/locales/da/components/input.json b/web/public/locales/da/components/input.json
index 0967ef424..0a8c89716 100644
--- a/web/public/locales/da/components/input.json
+++ b/web/public/locales/da/components/input.json
@@ -1 +1,10 @@
-{}
+{
+ "button": {
+ "downloadVideo": {
+ "label": "Download Video",
+ "toast": {
+ "success": "Din video til gennemgang er begyndt at blive downloadet."
+ }
+ }
+ }
+}
diff --git a/web/public/locales/da/components/player.json b/web/public/locales/da/components/player.json
index 0967ef424..9f9676ba3 100644
--- a/web/public/locales/da/components/player.json
+++ b/web/public/locales/da/components/player.json
@@ -1 +1,51 @@
-{}
+{
+ "noRecordingsFoundForThisTime": "Ingen optagelser fundet i det angivne tidsrum",
+ "noPreviewFound": "Ingen forhåndsvisning fundet",
+ "cameraDisabled": "Kamera er deaktiveret",
+ "noPreviewFoundFor": "Ingen forhåndsvisning fundet for {{cameraName}}",
+ "submitFrigatePlus": {
+ "title": "Indsend dette billede til Frigate+?",
+ "submit": "Indsend"
+ },
+ "livePlayerRequiredIOSVersion": "iOS 17.1 eller nyere kræves for denne type livestream.",
+ "streamOffline": {
+ "title": "Stream offline",
+ "desc": "Der er ikke modtaget nogen billeder på {{cameraName}}-detect-streamen, tjek fejllogs."
+ },
+ "stats": {
+ "streamType": {
+ "title": "Stream type:",
+ "short": "Type"
+ },
+ "bandwidth": {
+ "title": "Båndbredde:",
+ "short": "Båndbredde"
+ },
+ "latency": {
+ "title": "Latenstid:",
+ "value": "{{seconds}} sekunder",
+ "short": {
+ "title": "Latenstid",
+ "value": "{{seconds}} sek"
+ }
+ },
+ "droppedFrames": {
+ "short": {
+ "title": "Tabt",
+ "value": "{{droppedFrames}} billeder"
+ },
+ "title": "Tabte billeder:"
+ },
+ "totalFrames": "Antal billeder i alt:",
+ "decodedFrames": "Dekodede billeder:",
+ "droppedFrameRate": "Rate for tabte billeder:"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "Billede sendt til Frigate+"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "Kunne ikke sende billede til Frigate+"
+ }
+ }
+}
diff --git a/web/public/locales/da/objects.json b/web/public/locales/da/objects.json
index 0967ef424..99275fbe3 100644
--- a/web/public/locales/da/objects.json
+++ b/web/public/locales/da/objects.json
@@ -1 +1,120 @@
-{}
+{
+ "person": "Person",
+ "bicycle": "Cykel",
+ "car": "Bil",
+ "motorcycle": "Motorcykel",
+ "airplane": "Flyvemaskine",
+ "bus": "Bus",
+ "train": "Tog",
+ "boat": "Båd",
+ "traffic_light": "Trafiklys",
+ "vehicle": "Køretøj",
+ "skateboard": "Skateboard",
+ "door": "Dør",
+ "sink": "Håndvask",
+ "toothbrush": "Tandbørste",
+ "scissors": "Saks",
+ "clock": "Ur",
+ "fire_hydrant": "Brandhane",
+ "street_sign": "Gadeskilt",
+ "stop_sign": "Stopskilt",
+ "parking_meter": "Parkeringsautomat",
+ "bench": "Bænk",
+ "bird": "Fugl",
+ "cat": "Kat",
+ "dog": "Hund",
+ "horse": "Hest",
+ "sheep": "Får",
+ "cow": "Ko",
+ "elephant": "Elefant",
+ "bear": "Bjørn",
+ "zebra": "Zebra",
+ "giraffe": "Giraf",
+ "hat": "Hat",
+ "backpack": "Rygsæk",
+ "umbrella": "Paraply",
+ "shoe": "Sko",
+ "eye_glasses": "Briller",
+ "handbag": "Håndtaske",
+ "tie": "Slips",
+ "suitcase": "Kuffert",
+ "frisbee": "Frisbee",
+ "skis": "Ski",
+ "snowboard": "Snowboard",
+ "sports_ball": "Bold",
+ "kite": "Drage",
+ "baseball_bat": "Baseball Bat",
+ "baseball_glove": "Baseball hanske",
+ "surfboard": "Surfbræt",
+ "tennis_racket": "Tennis ketcher",
+ "bottle": "Flaske",
+ "plate": "Tallerken",
+ "wine_glass": "Vinglas",
+ "cup": "Kop",
+ "fork": "Gaffel",
+ "knife": "Kniv",
+ "spoon": "Ske",
+ "bowl": "Skål",
+ "banana": "Banan",
+ "apple": "Æble",
+ "sandwich": "Sandwich",
+ "orange": "Appelsin",
+ "broccoli": "Broccoli",
+ "carrot": "Gulerod",
+ "hot_dog": "Hotdog",
+ "pizza": "Pizza",
+ "donut": "Donut",
+ "cake": "Kage",
+ "chair": "Stol",
+ "couch": "Sofa",
+ "potted_plant": "Potteplante",
+ "bed": "Seng",
+ "mirror": "Spejl",
+ "dining_table": "Spisebord",
+ "window": "Vindue",
+ "desk": "Bord",
+ "toilet": "Toilet",
+ "tv": "Fjernsyn",
+ "laptop": "Bærebar computer",
+ "mouse": "Mus",
+ "remote": "Fjernbetjening",
+ "keyboard": "Tastatur",
+ "cell_phone": "Mobiltelefon",
+ "microwave": "Mikrobølgeovn",
+ "oven": "Ovn",
+ "toaster": "Brødrister",
+ "refrigerator": "Køleskab",
+ "blender": "Mixer",
+ "book": "Bog",
+ "vase": "Vase",
+ "teddy_bear": "Bamse",
+ "hair_dryer": "Føntørrer",
+ "hair_brush": "Hårbørste",
+ "squirrel": "Egern",
+ "deer": "Hjort",
+ "animal": "Dyr",
+ "bark": "Gø",
+ "fox": "Ræv",
+ "goat": "Gæd",
+ "rabbit": "Kanin",
+ "raccoon": "Vaskebjørn",
+ "robot_lawnmower": "Robotplæneklipper",
+ "waste_bin": "Affaldsspand",
+ "on_demand": "Manuel optagelse",
+ "face": "Ansigt",
+ "license_plate": "Nummerplade",
+ "package": "Pakke",
+ "bbq_grill": "Grill",
+ "amazon": "Amazon levering",
+ "usps": "USPS levering",
+ "ups": "UPS levering",
+ "fedex": "FedEx levering",
+ "dhl": "DHL levering",
+ "an_post": "An Post levering",
+ "purolator": "Purolator levering",
+ "postnl": "PostNL levering",
+ "nzpost": "NZPost levering",
+ "postnord": "PostNord levering",
+ "gls": "GLS levering",
+ "dpd": "DPD levering"
+}
diff --git a/web/public/locales/da/views/classificationModel.json b/web/public/locales/da/views/classificationModel.json
new file mode 100644
index 000000000..3193dbb59
--- /dev/null
+++ b/web/public/locales/da/views/classificationModel.json
@@ -0,0 +1,187 @@
+{
+ "documentTitle": "Kategoriseringsmodeller - Frigate",
+ "details": {
+ "scoreInfo": "Scoren viser den gennemsnitlige sikkerhed for kategoriseringen på tværs af alle registreringer af dette objekt.",
+ "unknown": "Ukendt",
+ "none": "Ingen"
+ },
+ "description": {
+ "invalidName": "Ugyldigt navn. Navne må kun indeholde bogstaver, tal, mellemrum, apostroffer, understregninger og bindestreger."
+ },
+ "button": {
+ "deleteClassificationAttempts": "Slet kategoriseringsbilleder",
+ "renameCategory": "Omdøb klasse",
+ "deleteCategory": "Slet klasse",
+ "deleteImages": "Slet billeder",
+ "trainModel": "Træn model",
+ "addClassification": "Tilføj Kategori",
+ "deleteModels": "Slet modeller",
+ "editModel": "Rediger model"
+ },
+ "tooltip": {
+ "trainingInProgress": "Modellen er ved at blive trænet",
+ "noNewImages": "Der er ingen nye billeder at lære af. Kategorisér flere billeder i datasættet først.",
+ "noChanges": "Ingen ændringer i datasættet siden sidste træning.",
+ "modelNotReady": "Modellen er ikke klar til træning"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Slettet kategori",
+ "deletedImage": "Slettede billeder",
+ "deletedModel_one": "{{count}} model er nu slettet",
+ "deletedModel_other": "{{count}} modeller er nu slettet",
+ "categorizedImage": "Billedet er nu kategoriseret",
+ "trainedModel": "Modellen er klar.",
+ "trainingModel": "Modeltræning er started.",
+ "updatedModel": "Modellens indstillinger er opdateret",
+ "renamedCategory": "Kategorien er omdøbt til {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Fejl under sletning: {{errorMessage}}",
+ "deleteCategoryFailed": "Sletning af kategori fejlede: {{errorMessage}}",
+ "deleteModelFailed": "Sletning af model fejlede: {{errorMessage}}",
+ "categorizeFailed": "Kategorisering af billedet fejlede: {{errorMessage}}",
+ "trainingFailed": "Træning af modellen fejlede. Check Frigate loggen.",
+ "trainingFailedToStart": "Opstart af modeltræning fejlede: {{errorMessage}}",
+ "updateModelFailed": "Ændring af modellen fejlede: {{errorMessage}}",
+ "renameCategoryFailed": "Kan ikke omdøbe kategorien: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Slet kategori",
+ "desc": "Er du sikker på at du vil slette kategorien {{name}}? Dette kan ikke fortrydes og sletter alle tilhørende billeder samt træning af modellen.",
+ "minClassesTitle": "Kan ikke slette Kategori",
+ "minClassesDesc": "Modellen skal have mindst 2 kategorier. Tilføj en kategori, før du sletter denne."
+ },
+ "deleteModel": {
+ "title": "Slet Kategoriseringsmodellen",
+ "desc_one": "Er du sikker på, at du vil slette {{count}} model? Dette vil permanent slette alle tilknyttede data, inkl. billeder og træningsdata. Denne handling kan ikke fortrydes.",
+ "desc_other": "Er du sikker på, at du vil slette {{count}} modeller? Dette vil permanent slette alle tilknyttede data, inkl. billeder og træningsdata. Denne handling kan ikke fortrydes.",
+ "single": "Er du sikker på, at du vil slette {{name}}? Dette vil permanent slette alle tilknyttede data, inklusive billeder og træningsdata. Denne handling kan ikke fortrydes."
+ },
+ "train": {
+ "title": "Nyeste kategorier",
+ "titleShort": "Nyeste",
+ "aria": "Vælg de nyeste kategorier"
+ },
+ "categories": "Kategorier",
+ "createCategory": {
+ "new": "Opret en ny kategori"
+ },
+ "categorizeImageAs": "Kategoriser billedet som:",
+ "categorizeImage": "Kategoriser billedet",
+ "menu": {
+ "objects": "Genstande",
+ "states": "Statestik"
+ },
+ "noModels": {
+ "object": {
+ "title": "Ingen kategoriseringsmodeller for genstande",
+ "description": "Opret en model, der kan kategorisere genstande.",
+ "buttonText": "Opret Genstands Model"
+ },
+ "state": {
+ "title": "Ingen modeller til genstandstilstande",
+ "description": "Opret en brugerdefineret model til at overvåge og kategorisere tilstandsændringer i specifikke kamerområder.",
+ "buttonText": "Opret tilstandsmodel"
+ }
+ },
+ "wizard": {
+ "step1": {
+ "type": "Type",
+ "typeState": "Tilstand",
+ "typeObject": "Genstand",
+ "objectLabel": "Genstands mærkat",
+ "objectLabelPlaceholder": "Vælg genstands type...",
+ "classificationType": "Kategoriseringstype",
+ "classificationTypeTip": "Udforsk kategoriseringstyper",
+ "errors": {
+ "nameLength": "Modellens navn må højst være 64 tegn",
+ "nameOnlyNumbers": "Modellens navn skal indeholde bogstaver",
+ "classRequired": "Der mangler en kategori",
+ "classesUnique": "Kategorinavne skal være unikke",
+ "noneNotAllowed": "Kategorinavnet 'none' er ikke tilladt",
+ "stateRequiresTwoClasses": "Tilstandsmodeller har brug for 2 kategorier",
+ "objectLabelRequired": "Vælg genstands mærkat",
+ "objectTypeRequired": "Vælg kategoriseringstype",
+ "nameRequired": "Modelnavn er påkrævet"
+ },
+ "description": "Tilstandsmodeller overvåger faste kameraområder for ændringer (f.eks. dør åben/lukket). Genstandsmodeller tilføjer kategoriseringer til detekterede genstande (f.eks. kendte dyr, leveringspersoner osv.).",
+ "name": "Navn",
+ "namePlaceholder": "Skriv modelnavn...",
+ "classificationTypeDesc": "Underetiketter tilføjer ekstra tekst til genstandens etiket (f.eks. 'Person: UPS'). Attributter er søgbare metadata, der opbevares separat i genstandens metadata.",
+ "classificationSubLabel": "Underetiketter",
+ "classificationAttribute": "Attribut",
+ "classes": "Kategori",
+ "states": "Tilstande",
+ "classesTip": "Lær om kategorier",
+ "classesStateDesc": "Definér de forskellige tilstande, dit kameraområde kan være i. For eksempel: 'åben' og 'lukket' for en garageport.",
+ "classesObjectDesc": "Definér de forskellige kategorier, som detekterede genstande skal kategoriseres i. For eksempel: 'leveringsperson', 'beboer', 'fremmed' til kategorisering af personer.",
+ "classPlaceholder": "Skriv kategorinavn..."
+ },
+ "step2": {
+ "description": "Vælg kameraer, og definer det område, der skal overvåges for hvert kamera. Modellen vil kategorisere tilstanden i disse områder.",
+ "cameras": "Kameraer",
+ "selectCamera": "Vælg Kamera",
+ "noCameras": "Klik + for at tilføje kamera",
+ "selectCameraPrompt": "Vælg et kamera fra listen for at definere dets overvågningsområde"
+ },
+ "step3": {
+ "selectImagesPrompt": "Vælg alle billeder med: {{className}}",
+ "selectImagesDescription": "Klik på billederne for at vælge dem. Klik på Fortsæt, når du er færdig med denne kategori.",
+ "allImagesRequired_one": "Venligst kategoriser alle billeder. {{count}} billede tilbage.",
+ "allImagesRequired_other": "Venligst kategoriser alle billeder. {{count}} billeder tilbage.",
+ "generating": {
+ "title": "Genererer testbilleder",
+ "description": "Frigate henter repræsentative billeder fra dine optagelser. Det kan tage et øjeblik..."
+ },
+ "training": {
+ "title": "Træningsmodel",
+ "description": "Din model trænes i baggrunden. Luk denne dialog, og din model vil begynde at køre, så snart træningen er færdig."
+ },
+ "retryGenerate": "Forsøg at generere igen",
+ "noImages": "Ingen prøvebilleder blev genereret",
+ "classifying": "Kategoriserer og træner...",
+ "trainingStarted": "Træningen er startet",
+ "modelCreated": "Model er oprettet. Brug visningen af nylige kategoriseringer til at tilføje billeder for de manglende tilstande, og træn modellen derefter.",
+ "errors": {
+ "noCameras": "Ingen kamera konfigureret",
+ "noObjectLabel": "Ingen genstandsmærkat valgt",
+ "generateFailed": "Kunne ikke generere eksempler: {{error}}",
+ "generationFailed": "Der opstod en fejl under genereringen. Prøv igen.",
+ "classifyFailed": "Kunne ikke kategorisere billederne: {{error}}"
+ },
+ "generateSuccess": "Eksempelbilleder er nu genereret",
+ "missingStatesWarning": {
+ "title": "Manglende tilstandseksempler",
+ "description": "Det anbefales at vælge eksempler for alle tilstande for at opnå de bedste resultater. Du kan fortsætte uden at vælge alle tilstande, men modellen bliver ikke trænet, før alle tilstande har billeder. Efter du fortsætter, kan du bruge visningen Seneste kategoriseringer til at kategorisere billeder for de manglende tilstande og derefter træne modellen."
+ }
+ },
+ "title": "Opret ny kategorisering",
+ "steps": {
+ "nameAndDefine": "Navn og definition",
+ "stateArea": "Tilstandsområde",
+ "chooseExamples": "Vælg Eksempler"
+ }
+ },
+ "edit": {
+ "title": "Rediger kategoriseringsmodel",
+ "descriptionState": "Rediger kategorierne for denne model til genstandstilstande. Ændringer kræver, at modellen trænes igen.",
+ "descriptionObject": "Rediger genstandstypen og kategoriseringstypen for denne genstandskategoriseringsmodel.",
+ "stateClassesInfo": "Bemærk: Ændring af tilstandskategorier kræver, at modellen trænes igen med de opdaterede kategorier."
+ },
+ "deleteDatasetImages": {
+ "title": "Slet billeder i datasættet",
+ "desc_one": "Er du sikker på, at du vil slette {{count}} billede fra {{dataset}}? Denne handling kan ikke fortrydes og kræver, at modellen trænes igen.",
+ "desc_other": "Er du sikker på, at du vil slette {{count}} billeder fra {{dataset}}? Denne handling kan ikke fortrydes og kræver, at modellen trænes igen."
+ },
+ "deleteTrainImages": {
+ "title": "Slet trænings billeder",
+ "desc_one": "Er du sikker på, at du vil slette {{count}} billede? Denne handling kan ikke fortrydes.",
+ "desc_other": "Er du sikker på, at du vil slette {{count}} billeder? Denne handling kan ikke fortrydes."
+ },
+ "renameCategory": {
+ "title": "Omdøb Kategori",
+ "desc": "Indtast et nyt navn til {{name}}. Modellen skal trænes igen, før navneændringen træder i kraft."
+ }
+}
diff --git a/web/public/locales/da/views/configEditor.json b/web/public/locales/da/views/configEditor.json
index 0967ef424..606479dba 100644
--- a/web/public/locales/da/views/configEditor.json
+++ b/web/public/locales/da/views/configEditor.json
@@ -1 +1,18 @@
-{}
+{
+ "documentTitle": "Konfigurationsstyring - Frigate",
+ "copyConfig": "Kopiér konfiguration",
+ "saveAndRestart": "Gem & Genstart",
+ "saveOnly": "Kun gem",
+ "configEditor": "Konfigurationsværktøj",
+ "safeConfigEditor": "Konfigurationsværktøj (Sikker tilstand)",
+ "safeModeDescription": "Frigate er i sikker tilstand på grund af valideringsfejl af konfigurationen.",
+ "confirm": "Afslut uden at gemme?",
+ "toast": {
+ "success": {
+ "copyToClipboard": "Konfigurationen er kopieret."
+ },
+ "error": {
+ "savingError": "Kan ikke gemme konfigurationen"
+ }
+ }
+}
diff --git a/web/public/locales/da/views/events.json b/web/public/locales/da/views/events.json
index 0967ef424..222c61e49 100644
--- a/web/public/locales/da/views/events.json
+++ b/web/public/locales/da/views/events.json
@@ -1 +1,31 @@
-{}
+{
+ "alerts": "Alarmer",
+ "detections": "Detekteringer",
+ "motion": {
+ "label": "Bevægelse",
+ "only": "Kun bevægelse"
+ },
+ "allCameras": "Alle kameraer",
+ "timeline": "Tidslinje",
+ "camera": "Kamera",
+ "empty": {
+ "alert": "Der er ingen advarsler at gennemgå",
+ "detection": "Der er ingen registreringer at gennemgå",
+ "motion": "Ingen bevægelsesdata fundet",
+ "recordingsDisabled": {
+ "title": "Optagelser skal være aktiveret"
+ }
+ },
+ "documentTitle": "Gennemse - Frigate",
+ "recordings": {
+ "documentTitle": "Optagelser - Frigate"
+ },
+ "calendarFilter": {
+ "last24Hours": "Sidste 24 timer"
+ },
+ "markAsReviewed": "Marker som gennemset",
+ "markTheseItemsAsReviewed": "Marker disse som gennemset",
+ "detail": {
+ "aria": "Skift til detaljevisning"
+ }
+}
diff --git a/web/public/locales/da/views/explore.json b/web/public/locales/da/views/explore.json
index 0967ef424..afe962aea 100644
--- a/web/public/locales/da/views/explore.json
+++ b/web/public/locales/da/views/explore.json
@@ -1 +1,29 @@
-{}
+{
+ "documentTitle": "Udforsk - Frigate",
+ "generativeAI": "Generativ AI",
+ "type": {
+ "details": "detaljer",
+ "video": "video"
+ },
+ "objectLifecycle": {
+ "lifecycleItemDesc": {
+ "active": "{{label}} blev aktiv"
+ }
+ },
+ "exploreIsUnavailable": {
+ "embeddingsReindexing": {
+ "startingUp": "Starter…",
+ "estimatedTime": "Estimeret tid tilbage:",
+ "context": "Udforsk kan bruges, når genindekseringen af de sporede objektindlejringer er fuldført.",
+ "finishingShortly": "Afsluttes om lidt",
+ "step": {
+ "thumbnailsEmbedded": "Miniaturer indlejret: "
+ }
+ },
+ "title": "Udforsk er ikke tilgængelig"
+ },
+ "exploreMore": "Udforsk flere {{label}}-objekter",
+ "details": {
+ "timestamp": "Tidsstempel"
+ }
+}
diff --git a/web/public/locales/da/views/exports.json b/web/public/locales/da/views/exports.json
index 0967ef424..6a821b3cd 100644
--- a/web/public/locales/da/views/exports.json
+++ b/web/public/locales/da/views/exports.json
@@ -1 +1,18 @@
-{}
+{
+ "documentTitle": "Eksporter - Frigate",
+ "search": "Søg",
+ "deleteExport.desc": "Er du sikker på at du vil slette {{exportName}}?",
+ "editExport": {
+ "title": "Omdøb Eksport",
+ "saveExport": "Gem Eksport",
+ "desc": "Indtast et nyt navn for denne eksport."
+ },
+ "noExports": "Ingen eksporter fundet",
+ "deleteExport": "Slet eksport",
+ "tooltip": {
+ "shareExport": "Del eksport",
+ "downloadVideo": "Download video",
+ "editName": "Rediger navn",
+ "deleteExport": "Slette eksport"
+ }
+}
diff --git a/web/public/locales/da/views/faceLibrary.json b/web/public/locales/da/views/faceLibrary.json
index 87f3a3437..40441517c 100644
--- a/web/public/locales/da/views/faceLibrary.json
+++ b/web/public/locales/da/views/faceLibrary.json
@@ -1,3 +1,22 @@
{
- "selectItem": "Vælg {{item}}"
+ "selectItem": "Vælg {{item}}",
+ "description": {
+ "addFace": "Tilføj en ny samling til ansigtsbiblioteket ved at uploade dit første billede.",
+ "placeholder": "Angiv et navn for bibliotek",
+ "invalidName": "Ugyldigt navn. Navne må kun indeholde bogstaver, tal, mellemrum, apostroffer, understregninger og bindestreger."
+ },
+ "details": {
+ "person": "Person",
+ "timestamp": "Tidsstempel",
+ "unknown": "Ukendt",
+ "scoreInfo": "Scoren er et vægtet gennemsnit af alle ansigtsscorer, vægtet efter ansigtets størrelse på hvert billede."
+ },
+ "documentTitle": "Ansigtsbibliotek - Frigate",
+ "uploadFaceImage": {
+ "title": "Upload ansigtsbillede",
+ "desc": "Upload et billede for at scanne efter ansigter og inkludere det for {{pageToggle}}"
+ },
+ "train": {
+ "titleShort": "Nyeste"
+ }
}
diff --git a/web/public/locales/da/views/live.json b/web/public/locales/da/views/live.json
index 0967ef424..6de5619fd 100644
--- a/web/public/locales/da/views/live.json
+++ b/web/public/locales/da/views/live.json
@@ -1 +1,117 @@
-{}
+{
+ "documentTitle": "Live - Frigate",
+ "documentTitle.withCamera": "{{camera}} - Live - Frigate",
+ "twoWayTalk": {
+ "enable": "Aktivér tovejskommunikation",
+ "disable": "Deaktiver tovejskommunikation"
+ },
+ "cameraAudio": {
+ "enable": "Aktivér kameralyd",
+ "disable": "Deaktivér kamera lyd"
+ },
+ "lowBandwidthMode": "Lavbåndbredde-tilstand",
+ "ptz": {
+ "move": {
+ "clickMove": {
+ "label": "Klik i billedrammen for at centrere kameraet",
+ "enable": "Aktivér klik for at flytte",
+ "disable": "Deaktiver klik for at flytte"
+ },
+ "left": {
+ "label": "Flyt PTZ-kameraet til venstre"
+ },
+ "up": {
+ "label": "Flyt PTZ kamera op"
+ },
+ "down": {
+ "label": "Flyt PTZ-kameraet ned"
+ },
+ "right": {
+ "label": "Flyt PTZ-kameraet til højre"
+ }
+ },
+ "zoom": {
+ "in": {
+ "label": "Zoom PTZ-kamera ind"
+ },
+ "out": {
+ "label": "Zoom PTZ kamera ud"
+ }
+ },
+ "focus": {
+ "in": {
+ "label": "Focus PTZ kamera ind"
+ },
+ "out": {
+ "label": "Focus PTZ kamera ud"
+ }
+ },
+ "frame": {
+ "center": {
+ "label": "Klik på billedet for at centrere PTZ-kameraet"
+ }
+ },
+ "presets": "PTZ kamera forudindstillinger"
+ },
+ "camera": {
+ "enable": "Aktivér kamera",
+ "disable": "Deaktivér kamera"
+ },
+ "muteCameras": {
+ "enable": "Slå lyd på alle kameraer fra",
+ "disable": "Slå lyd på alle kameraer til"
+ },
+ "detect": {
+ "enable": "Aktiver detektering",
+ "disable": "Deaktiver detektering"
+ },
+ "recording": {
+ "enable": "Aktivér optagelse",
+ "disable": "Deaktiver optagelse"
+ },
+ "snapshots": {
+ "enable": "Aktivér Snapshots",
+ "disable": "Deaktivér Snapshots"
+ },
+ "snapshot": {
+ "takeSnapshot": "Hent instant snapshot",
+ "noVideoSource": "Ingen videokilde til snapshot.",
+ "captureFailed": "Kunne ikke tage snapshot.",
+ "downloadStarted": "Hentning af snapshot startet."
+ },
+ "audioDetect": {
+ "enable": "Aktiver lyddetektor",
+ "disable": "Deaktiver lyddetektor"
+ },
+ "transcription": {
+ "enable": "Aktiver Live Audio Transkription",
+ "disable": "Deaktiver Live Audio Transkription"
+ },
+ "autotracking": {
+ "enable": "Aktiver Autotracking",
+ "disable": "Deaktiver Autotracking"
+ },
+ "streamStats": {
+ "enable": "Vis Stream statistik",
+ "disable": "Skjul Stream statistik"
+ },
+ "manualRecording": {
+ "title": "Manuel optagelse",
+ "tips": "Hent et øjebliksbillede eller start en manuel begivenhed baseret på dette kameras indstillinger for optagelse af opbevaring.",
+ "playInBackground": {
+ "label": "Afspil i baggrunden",
+ "desc": "Aktiver denne mulighed for at fortsætte streaming, når afspilleren er skjult."
+ },
+ "showStats": {
+ "label": "Vis statistik",
+ "desc": "Aktiver denne mulighed for at vise streamstatistikker som en overlejring på kameraets feed."
+ },
+ "debugView": "Debug View",
+ "start": "Start on-demand optagelse",
+ "started": "Start manuel optagelse.",
+ "failedToStart": "Manuel optagelse fejlede.",
+ "recordDisabledTips": "Da optagelsen er deaktiveret eller begrænset i konfig for dette kamera, gemmes der kun et snapshot.",
+ "end": "Afslut manuel optagelse",
+ "ended": "Afsluttet manuel optagelse."
+ }
+}
diff --git a/web/public/locales/da/views/recording.json b/web/public/locales/da/views/recording.json
index 0967ef424..4028727ac 100644
--- a/web/public/locales/da/views/recording.json
+++ b/web/public/locales/da/views/recording.json
@@ -1 +1,12 @@
-{}
+{
+ "filter": "Filter",
+ "export": "Eksporter",
+ "calendar": "Kalender",
+ "filters": "Filtere",
+ "toast": {
+ "error": {
+ "endTimeMustAfterStartTime": "Sluttidspunkt skal være efter starttidspunkt",
+ "noValidTimeSelected": "Intet gyldigt tidsinterval valgt"
+ }
+ }
+}
diff --git a/web/public/locales/da/views/search.json b/web/public/locales/da/views/search.json
index 0967ef424..d643b298d 100644
--- a/web/public/locales/da/views/search.json
+++ b/web/public/locales/da/views/search.json
@@ -1 +1,13 @@
-{}
+{
+ "search": "Søg",
+ "savedSearches": "Gemte Søgninger",
+ "searchFor": "Søg efter {{inputValue}}",
+ "button": {
+ "save": "Gem søgning",
+ "delete": "Slet gemt søgning",
+ "filterInformation": "Filter information",
+ "filterActive": "Filtre aktiv",
+ "clear": "Ryd søgning"
+ },
+ "trackedObjectId": "Sporet genstands-ID"
+}
diff --git a/web/public/locales/da/views/settings.json b/web/public/locales/da/views/settings.json
index 0967ef424..61fce336f 100644
--- a/web/public/locales/da/views/settings.json
+++ b/web/public/locales/da/views/settings.json
@@ -1 +1,14 @@
-{}
+{
+ "documentTitle": {
+ "default": "Indstillinger - Frigate",
+ "authentication": "Bruger Indstillinger - Frigate",
+ "camera": "Kamera indstillinger - Frigate",
+ "object": "Debug - Frigate",
+ "cameraManagement": "Administrér kameraer - Frigate",
+ "cameraReview": "Indstillinger for kameragennemgang - Frigate",
+ "enrichments": "Indstillinger for berigelser - Frigate",
+ "masksAndZones": "Maske- og zoneeditor - Frigate",
+ "motionTuner": "Bevægelsesjustering - Frigate",
+ "general": "Brugergrænsefladeindstillinger - Frigate"
+ }
+}
diff --git a/web/public/locales/da/views/system.json b/web/public/locales/da/views/system.json
index 0967ef424..31d7ac946 100644
--- a/web/public/locales/da/views/system.json
+++ b/web/public/locales/da/views/system.json
@@ -1 +1,103 @@
-{}
+{
+ "documentTitle": {
+ "cameras": "Kamera Statistik - Frigate",
+ "storage": "Lagrings Statistik - Frigate",
+ "logs": {
+ "frigate": "Frigate Logs - Frigate",
+ "go2rtc": "Go2RTC Logs - Frigate",
+ "nginx": "Nginx Logs - Frigate"
+ },
+ "general": "Generelle statistikker - Frigate",
+ "enrichments": "Beredningsstatistikker - Frigate"
+ },
+ "title": "System",
+ "logs": {
+ "copy": {
+ "label": "Kopier til udklipsholder",
+ "success": "Logs er kopieret til udklipsholder",
+ "error": "Kunne ikke kopiere logs til udklipsholder"
+ },
+ "type": {
+ "label": "Type",
+ "timestamp": "Tidsstempel",
+ "message": "Besked",
+ "tag": "Tag"
+ },
+ "tips": "Logs bliver streamet fra serveren",
+ "toast": {
+ "error": {
+ "fetchingLogsFailed": "Fejl ved indhentning af logs: {{errorMessage}}",
+ "whileStreamingLogs": "Fejl ved streaming af logs: {{errorMessage}}"
+ }
+ },
+ "download": {
+ "label": "Download logs"
+ }
+ },
+ "general": {
+ "title": "Generelt",
+ "hardwareInfo": {
+ "gpuUsage": "GPU forbrug",
+ "gpuMemory": "GPU hukommelse",
+ "gpuEncoder": "GPU indkoder",
+ "gpuDecoder": "GPU afkoder",
+ "title": "Hardware information",
+ "gpuInfo": {
+ "closeInfo": {
+ "label": "Luk GPU information"
+ },
+ "copyInfo": {
+ "label": "Kopier GPU information"
+ },
+ "toast": {
+ "success": "Kopierede GPU information til udklipsholder"
+ }
+ },
+ "npuUsage": "NPU forbrug",
+ "npuMemory": "NPU hukommelse"
+ },
+ "detector": {
+ "title": "Detektorer",
+ "inferenceSpeed": "Detektorinferenshastighed",
+ "temperature": "Detektor temperatur",
+ "cpuUsage": "Detektor CPU forbrug",
+ "cpuUsageInformation": "CPU brugt til at forberede input- og outputdata til/fra detektionsmodeller. Denne værdi måler ikke inferensforbrug, selvom der bruges en GPU eller accelerator.",
+ "memoryUsage": "Detektorhummelsesforbrug"
+ },
+ "otherProcesses": {
+ "title": "Andre processer",
+ "processCpuUsage": "Proces CPU forbrug",
+ "processMemoryUsage": "Proceshukommelsesforbrug"
+ }
+ },
+ "metrics": "System metrikker",
+ "storage": {
+ "title": "Lagring",
+ "overview": "Overblik",
+ "recordings": {
+ "title": "Optagelser",
+ "tips": "Denne værdi repræsenterer den samlede lagerplads, der bruges af optagelserne i Frigates database. Frigate sporer ikke lagerpladsforbruget for alle filer på din disk.",
+ "earliestRecording": "Tidligste optagelse til rådighed:"
+ },
+ "shm": {
+ "title": "SHM (delt hukommelse) tildeling",
+ "warning": "Den nuværende SHM størrelse af {{total}}MB er for lille. Øg den til minimum {{min_shm}}MB."
+ },
+ "cameraStorage": {
+ "title": "Kamera lagring",
+ "camera": "Kamera",
+ "unusedStorageInformation": "Ubrugt lagringsinformation",
+ "storageUsed": "Lagring",
+ "percentageOfTotalUsed": "Procentandel af total",
+ "bandwidth": "Båndbredde",
+ "unused": {
+ "title": "Ubrugt",
+ "tips": "Denne værdi repræsenterer muligvis ikke nøjagtigt den ledige plads, der er tilgængelig for Frigate, hvis du har andre filer gemt på dit drev ud over Frigates optagelser. Frigate sporer ikke lagerforbrug ud over sine optagelser."
+ }
+ }
+ },
+ "cameras": {
+ "title": "Kameraer",
+ "overview": "Overblik"
+ }
+}
diff --git a/web/public/locales/de/audio.json b/web/public/locales/de/audio.json
index 0e0e50935..4b1877501 100644
--- a/web/public/locales/de/audio.json
+++ b/web/public/locales/de/audio.json
@@ -296,7 +296,7 @@
"doorbell": "Türklingel",
"ding-dong": "BimBam",
"sliding_door": "Schiebetür",
- "slam": "Knall",
+ "slam": "zuknallen",
"knock": "Klopfen",
"tap": "Schlag",
"squeak": "Quietschen",
@@ -355,7 +355,7 @@
"shatter": "Zerspringen",
"silence": "Stille",
"environmental_noise": "Umgebungsgeräusch",
- "static": "Rauschen",
+ "static": "Statisch",
"pink_noise": "Rosa Rauschen",
"television": "Fernsehgerät",
"radio": "Radio",
@@ -425,5 +425,79 @@
"sanding": "Schleifen",
"machine_gun": "Maschinengewehr",
"boom": "Dröhnen",
- "field_recording": "Außenaufnahme"
+ "field_recording": "Außenaufnahme",
+ "liquid": "Flüssigkeit",
+ "splash": "Spritzer",
+ "slosh": "Schwenken",
+ "squish": "Quetschen",
+ "drip": "Tropfen",
+ "pour": "Gießen",
+ "trickle": "Tröpfeln",
+ "fill": "Füllen",
+ "spray": "Sprühen",
+ "pump": "Pumpen",
+ "stir": "Umrühren",
+ "boiling": "Köchelnd",
+ "arrow": "Pfeil",
+ "electronic_tuner": "Elektronischer Tuner",
+ "effects_unit": "Effekteinheit",
+ "chorus_effect": "Chorus-Effekt",
+ "sodeling": "Verfilzen",
+ "chird": "Akkord",
+ "change_ringing": "Wechsle RingRing",
+ "shofar": "Schofar",
+ "gush": "sprudeln",
+ "sonar": "Sonar",
+ "whoosh": "Rauschen",
+ "thump": "Ruck",
+ "basketball_bounce": "Basketball Abbraller",
+ "bang": "Knall",
+ "slap": "Ohrfeige",
+ "whack": "verhauen",
+ "smash": "zerschlagen",
+ "breaking": "zerbrechen",
+ "bouncing": "Abbraller",
+ "whip": "Peitsche",
+ "flap": "Lasche",
+ "scratch": "Kratzer",
+ "scrape": "Abfall",
+ "rub": "scheuern",
+ "roll": "rollen",
+ "crushing": "Stauchen",
+ "crumpling": "zerknüllen",
+ "tearing": "Reißen",
+ "beep": "Piep",
+ "ping": "Ping",
+ "ding": "klingeln",
+ "thunk": "dumpfes Geräusch",
+ "clang": "Geklirr",
+ "squeal": "Ausruf",
+ "creak": "Knarren",
+ "rustle": "Geknister",
+ "whir": "schwirren",
+ "clatter": "Geratter",
+ "sizzle": "brutzeln",
+ "clicking": "Klicken",
+ "clickety_clack": "Klappergeräuschen",
+ "rumble": "Grollen",
+ "plop": "plumpsen",
+ "hum": "Brummen",
+ "zing": "Schwung",
+ "boing": "ferderndes Geräusch",
+ "crunch": "knirschendes",
+ "sine_wave": "Sinus Kurve",
+ "harmonic": "harmonisch",
+ "chirp_tone": "Frequenzwobbelung",
+ "pulse": "Takt",
+ "inside": "drinnen",
+ "outside": "draußen",
+ "reverberation": "Widerhall",
+ "echo": "Echo",
+ "noise": "Lärm",
+ "mains_hum": "Netzbrummen",
+ "distortion": "Verzerrung",
+ "sidetone": "Nebengeräusch",
+ "cacophony": "Dissonanz",
+ "throbbing": "Pochen",
+ "vibration": "Vibration"
}
diff --git a/web/public/locales/de/common.json b/web/public/locales/de/common.json
index 8a3eff88c..8ecd25ab6 100644
--- a/web/public/locales/de/common.json
+++ b/web/public/locales/de/common.json
@@ -12,13 +12,13 @@
"24hours": "24 Stunden",
"month_one": "{{time}} Monat",
"month_other": "{{time}} Monate",
- "d": "{{time}} Tag",
+ "d": "{{time}} Tg.",
"day_one": "{{time}} Tag",
"day_other": "{{time}} Tage",
- "m": "{{time}} Minute",
+ "m": "{{time}} Min",
"minute_one": "{{time}} Minute",
"minute_other": "{{time}} Minuten",
- "s": "{{time}} Sekunde",
+ "s": "{{time}}s",
"second_one": "{{time}} Sekunde",
"second_other": "{{time}} Sekunden",
"formattedTimestamp2": {
@@ -37,12 +37,12 @@
"30minutes": "30 Minuten",
"1hour": "1 Stunde",
"lastWeek": "Letzte Woche",
- "h": "{{time}} Stunde",
- "ago": "{{timeAgo}} her",
+ "h": "{{time}} Std.",
+ "ago": "vor {{timeAgo}}",
"untilRestart": "Bis zum Neustart",
"justNow": "Gerade",
"pm": "nachmittags",
- "mo": "{{time}}Monat",
+ "mo": "{{time}} Mon.",
"formattedTimestamp": {
"12hour": "d. MMM, hh:mm:ss aaa",
"24hour": "dd. MMM, hh:mm:ss aaa"
@@ -81,7 +81,11 @@
"formattedTimestampMonthDayYear": {
"12hour": "d. MMM yyyy",
"24hour": "d. MMM yyyy"
- }
+ },
+ "inProgress": "Im Gange",
+ "invalidStartTime": "Ungültige Startzeit",
+ "invalidEndTime": "Ungültige Endzeit",
+ "never": "Nie"
},
"button": {
"save": "Speichern",
@@ -107,7 +111,7 @@
"off": "AUS",
"reset": "Zurücksetzen",
"copy": "Kopieren",
- "twoWayTalk": "bidirecktionales Gespräch",
+ "twoWayTalk": "Zwei-Wege-Kommunikation",
"exitFullscreen": "Vollbild verlassen",
"unselect": "Selektion aufheben",
"copyCoordinates": "Kopiere Koordinaten",
@@ -118,10 +122,17 @@
"pictureInPicture": "Bild in Bild",
"on": "AN",
"suspended": "Pausierte",
- "unsuspended": "fortsetzen"
+ "unsuspended": "fortsetzen",
+ "continue": "Weiter"
},
"label": {
- "back": "Zurück"
+ "back": "Zurück",
+ "hide": "Verstecke {{item}}",
+ "show": "Zeige {{item}}",
+ "ID": "ID",
+ "none": "Nichts",
+ "all": "Alle",
+ "other": "andere"
},
"menu": {
"configurationEditor": "Konfigurationseditor",
@@ -160,7 +171,16 @@
"sk": "Slowakisch",
"yue": "粵語 (Kantonesisch)",
"th": "ไทย (Thailändisch)",
- "ca": "Català (Katalanisch)"
+ "ca": "Català (Katalanisch)",
+ "ur": "اردو (Urdu)",
+ "ptBR": "Portugiesisch (Brasilianisch)",
+ "sr": "Српски (Serbisch)",
+ "sl": "Slovenščina (Slowenisch)",
+ "lt": "Lietuvių (Litauisch)",
+ "bg": "Български (bulgarisch)",
+ "gl": "Galego (Galicisch)",
+ "id": "Bahasa Indonesia (Indonesisch)",
+ "hr": "Hrvatski (Kroatisch)"
},
"appearance": "Erscheinung",
"theme": {
@@ -168,7 +188,7 @@
"blue": "Blau",
"green": "Grün",
"default": "Standard",
- "nord": "Norden",
+ "nord": "Nord",
"red": "Rot",
"contrast": "Hoher Kontrast",
"highcontrast": "Hoher Kontrast"
@@ -214,7 +234,8 @@
"logout": "Abmelden"
},
"uiPlayground": "Testgebiet für Benutzeroberfläche",
- "export": "Exportieren"
+ "export": "Exportieren",
+ "classification": "Klassifizierung"
},
"unit": {
"speed": {
@@ -224,10 +245,18 @@
"length": {
"feet": "Fuß",
"meters": "Meter"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/Stunde",
+ "mbph": "MB/Stunde",
+ "gbph": "GB/Stunde"
}
},
"toast": {
- "copyUrlToClipboard": "URL in zwischenablage kopiert.",
+ "copyUrlToClipboard": "URL in Zwischenablage kopiert.",
"save": {
"error": {
"title": "Speichern der Konfigurationsänderungen gescheitert: {{errorMessage}}",
@@ -240,7 +269,7 @@
"title": "Rolle",
"admin": "Administrator",
"viewer": "Zuschauer",
- "desc": "Administratoren haben vollen Zugang zu allen funktionen der Frigate Benutzeroberfläche. Zuschauer können nur Kameras betrachten, erkannte Objekte überprüfen und historische Aufnahmen durchsehen."
+ "desc": "Administratoren haben vollen Zugang zu allen Funktionen der Frigate Benutzeroberfläche. Zuschauer können nur Kameras betrachten, erkannte Objekte überprüfen und historische Aufnahmen durchsehen."
},
"pagination": {
"previous": {
@@ -260,9 +289,22 @@
"documentTitle": "Nicht gefunden - Frigate"
},
"selectItem": "Wähle {{item}}",
+ "readTheDocumentation": "Dokumentation lesen",
"accessDenied": {
"desc": "Du hast keine Berechtigung diese Seite anzuzeigen.",
"documentTitle": "Zugang verweigert - Frigate",
"title": "Zugang verweigert"
+ },
+ "information": {
+ "pixels": "{{area}}px"
+ },
+ "field": {
+ "optional": "Optional",
+ "internalID": "Die interne ID, die Frigate in der Konfiguration und Datenbank verwendet"
+ },
+ "list": {
+ "two": "{{0}} und {{1}}",
+ "many": "{{items}}, und {{last}}",
+ "separatorWithSpace": ", "
}
}
diff --git a/web/public/locales/de/components/auth.json b/web/public/locales/de/components/auth.json
index 8cbd1ff8c..2c4886641 100644
--- a/web/public/locales/de/components/auth.json
+++ b/web/public/locales/de/components/auth.json
@@ -10,6 +10,7 @@
"unknownError": "Unbekannter Fehler. Prüfe Logs."
},
"user": "Benutzername",
- "password": "Kennwort"
+ "password": "Kennwort",
+ "firstTimeLogin": "Ist dies der erste Loginversuch? Die Zugangsdaten werden in den Frigate Logs angezeigt."
}
}
diff --git a/web/public/locales/de/components/camera.json b/web/public/locales/de/components/camera.json
index fb6f89e74..32874bab6 100644
--- a/web/public/locales/de/components/camera.json
+++ b/web/public/locales/de/components/camera.json
@@ -58,7 +58,8 @@
"desc": "Ändere die Live Stream Optionen für das Dashboard dieser Kameragruppe. Diese Einstellungen sind geräte-/browserspezifisch.",
"stream": "Stream",
"placeholder": "Wähle einen Stream"
- }
+ },
+ "birdseye": "Vogelperspektive"
},
"add": "Kameragruppe hinzufügen",
"cameras": {
diff --git a/web/public/locales/de/components/dialog.json b/web/public/locales/de/components/dialog.json
index cedd1c114..464db5adf 100644
--- a/web/public/locales/de/components/dialog.json
+++ b/web/public/locales/de/components/dialog.json
@@ -66,7 +66,8 @@
"failed": "Fehler beim Starten des Exports: {{error}}",
"noVaildTimeSelected": "Kein gültiger Zeitraum ausgewählt"
},
- "success": "Export erfolgreich gestartet. Die Datei befindet sich im Ordner /exports."
+ "success": "Export erfolgreich gestartet. Die Datei befindet sich auf der Exportseite.",
+ "view": "Ansicht"
},
"fromTimeline": {
"saveExport": "Export speichern",
@@ -117,7 +118,16 @@
"button": {
"export": "Exportieren",
"markAsReviewed": "Als geprüft markieren",
- "deleteNow": "Jetzt löschen"
+ "deleteNow": "Jetzt löschen",
+ "markAsUnreviewed": "Als ungeprüft markieren"
}
+ },
+ "imagePicker": {
+ "selectImage": "Vorschaubild eines verfolgten Objekts selektieren",
+ "search": {
+ "placeholder": "Nach Label oder Unterlabel suchen..."
+ },
+ "noImages": "Kein Vorschaubild für diese Kamera gefunden",
+ "unknownLabel": "Gespeichertes Triggerbild"
}
}
diff --git a/web/public/locales/de/components/filter.json b/web/public/locales/de/components/filter.json
index a2c7db779..d593080cd 100644
--- a/web/public/locales/de/components/filter.json
+++ b/web/public/locales/de/components/filter.json
@@ -101,7 +101,7 @@
"title": "Lade",
"desc": "Wenn das Protokollfenster nach unten gescrollt wird, werden neue Protokolle automatisch geladen, sobald sie hinzugefügt werden."
},
- "disableLogStreaming": "Log des Streams deaktvieren",
+ "disableLogStreaming": "Log des Streams deaktivieren",
"allLogs": "Alle Logs"
},
"trackedObjectDelete": {
@@ -121,6 +121,20 @@
"loadFailed": "Bekannte Nummernschilder konnten nicht geladen werden.",
"loading": "Lade bekannte Nummernschilder…",
"placeholder": "Tippe, um Kennzeichen zu suchen…",
- "selectPlatesFromList": "Wählen eine oder mehrere Kennzeichen aus der Liste aus."
+ "selectPlatesFromList": "Wählen eine oder mehrere Kennzeichen aus der Liste aus.",
+ "selectAll": "Alle wählen",
+ "clearAll": "Alle löschen"
+ },
+ "classes": {
+ "label": "Klassen",
+ "all": {
+ "title": "Alle Klassen"
+ },
+ "count_one": "{{count}} Klasse",
+ "count_other": "{{count}} Klassen"
+ },
+ "attributes": {
+ "label": "Klassifizierungsattribute",
+ "all": "Alle Attribute"
}
}
diff --git a/web/public/locales/de/components/player.json b/web/public/locales/de/components/player.json
index a6b251f01..56a195053 100644
--- a/web/public/locales/de/components/player.json
+++ b/web/public/locales/de/components/player.json
@@ -24,7 +24,7 @@
"title": "Latenz:",
"value": "{{seconds}} Sekunden",
"short": {
- "title": "Lazenz",
+ "title": "Latenz",
"value": "{{seconds}} s"
}
},
diff --git a/web/public/locales/de/objects.json b/web/public/locales/de/objects.json
index 57fb35617..f3fdbd370 100644
--- a/web/public/locales/de/objects.json
+++ b/web/public/locales/de/objects.json
@@ -27,7 +27,7 @@
"donut": "Donut",
"cake": "Kuchen",
"chair": "Stuhl",
- "couch": "Couch",
+ "couch": "Sofa",
"bed": "Bett",
"dining_table": "Esstisch",
"toilet": "Toilette",
diff --git a/web/public/locales/de/views/classificationModel.json b/web/public/locales/de/views/classificationModel.json
new file mode 100644
index 000000000..2de77e73e
--- /dev/null
+++ b/web/public/locales/de/views/classificationModel.json
@@ -0,0 +1,188 @@
+{
+ "documentTitle": "Klassifikationsmodelle - Frigate",
+ "details": {
+ "scoreInfo": "Die Punktzahl gibt die durchschnittliche Konfidenz aller Erkennungen dieses Objekts wieder.",
+ "none": "Keiner",
+ "unknown": "Unbekannt"
+ },
+ "button": {
+ "deleteClassificationAttempts": "Lösche klassifizierte Bilder",
+ "renameCategory": "Klasse umbenennen",
+ "deleteCategory": "Klasse löschen",
+ "deleteImages": "Bilder löschen",
+ "trainModel": "Modell trainieren",
+ "addClassification": "Klassifikationsmodell hinzufügen",
+ "deleteModels": "Modell löschen",
+ "editModel": "Modell bearbeiten"
+ },
+ "tooltip": {
+ "trainingInProgress": "Modell wird gerade trainiert",
+ "noNewImages": "Keine weiteren Bilder zum trainieren. Bitte klassifiziere weitere Bilder im Datensatz.",
+ "noChanges": "Keine Veränderungen des Datensatzes seit dem letzten Training.",
+ "modelNotReady": "Modell ist nicht bereit für das Training"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Klasse gelöscht",
+ "deletedImage": "Bilder gelöscht",
+ "deletedModel_one": "{{count}} Modell erfolgreich gelöscht",
+ "deletedModel_other": "{{count}} Modelle erfolgreich gelöscht",
+ "categorizedImage": "Erfolgreich klassifizierte Bilder",
+ "trainedModel": "Modell erfolgreich trainiert.",
+ "trainingModel": "Modelltraining erfolgreich gestartet.",
+ "updatedModel": "Modellkonfiguration erfolgreich aktualisiert",
+ "renamedCategory": "Klasse erfolgreich in {{name}} umbenannt"
+ },
+ "error": {
+ "deleteImageFailed": "Löschen fehlgeschlagen: {{errorMessage}}",
+ "deleteCategoryFailed": "Löschen der Klasse fehlgeschlagen: {{errorMessage}}",
+ "deleteModelFailed": "Model konnte nicht gelöscht werden: {{errorMessage}}",
+ "trainingFailedToStart": "Modelltraining konnte nicht gestartet werden: {{errorMessage}}",
+ "updateModelFailed": "Aktualisierung des Modells fehlgeschlagen: {{errorMessage}}",
+ "renameCategoryFailed": "Umbenennung der Klasse fehlgeschlagen: {{errorMessage}}",
+ "categorizeFailed": "Bildkategorisierung fehlgeschlagen: {{errorMessage}}",
+ "trainingFailed": "Modelltraining fehlgeschlagen. Details sind in den Frigate-Protokollen zu finden."
+ }
+ },
+ "deleteCategory": {
+ "title": "Klasse löschen",
+ "desc": "Möchten Sie die Klasse {{name}} wirklich löschen? Dadurch werden alle zugehörigen Bilder dauerhaft gelöscht und das Modell muss neu trainiert werden.",
+ "minClassesTitle": "Klasse kann nicht gelöscht werden",
+ "minClassesDesc": "Ein Klassifizierungsmodell benötigt mindestens zwei Klassen. Fügen Sie eine weitere Klasse hinzu, bevor Sie diese löschen."
+ },
+ "deleteModel": {
+ "title": "Klassifizierungsmodell löschen",
+ "single": "Möchten Sie {{name}} wirklich löschen? Dadurch werden alle zugehörigen Daten, einschließlich Bilder und Trainingsdaten, dauerhaft gelöscht. Diese Aktion kann nicht rückgängig gemacht werden.",
+ "desc_one": "Möchtest du {{count}} Modell wirklich löschen? Dadurch werden alle zugehörigen Daten, einschließlich Bilder und Trainingsdaten, dauerhaft gelöscht. Diese Aktion kann nicht rückgängig gemacht werden.",
+ "desc_other": "Möchtest du {{count}} Modelle wirklich löschen? Dadurch werden alle zugehörigen Daten, einschließlich Bilder und Trainingsdaten, dauerhaft gelöscht. Diese Aktion kann nicht rückgängig gemacht werden."
+ },
+ "edit": {
+ "title": "Klassifikationsmodell bearbeiten",
+ "descriptionState": "Bearbeite die Klassen für dieses Zustandsklassifikationsmodell. Änderungen erfordern ein erneutes Trainieren des Modells.",
+ "descriptionObject": "Bearbeite den Objekttyp und Klassifizierungstyp für dieses Objektklassifikationsmodell.",
+ "stateClassesInfo": "Hinweis: Die Änderung der Statusklassen erfordert ein erneutes Trainieren des Modells mit den aktualisierten Klassen."
+ },
+ "deleteDatasetImages": {
+ "title": "Datensatz Bilder löschen",
+ "desc_one": "Bist du sicher, dass {{count}} Bild von {{dataset}} gelöscht werden sollen? Diese Aktion kann nicht rückgängig gemacht werden und erfordert ein erneutes Trainieren des Modells.",
+ "desc_other": "Bist du sicher, dass {{count}} Bilder von {{dataset}} gelöscht werden sollen? Diese Aktion kann nicht rückgängig gemacht werden und erfordert ein erneutes Trainieren des Modells."
+ },
+ "deleteTrainImages": {
+ "title": "Trainingsbilder löschen",
+ "desc_one": "Bist du sicher, dass du {{count}} Bild löschen möchten? Diese Aktion kann nicht rückgängig gemacht werden.",
+ "desc_other": "Bist du sicher, dass du {{count}} Bilder löschen möchten? Diese Aktion kann nicht rückgängig gemacht werden."
+ },
+ "renameCategory": {
+ "title": "Klasse umbenennen",
+ "desc": "Neuen Namen für {{name}} eingeben. Das Modell muss neu trainiert werden, damit die Änderungen wirksam werden."
+ },
+ "description": {
+ "invalidName": "Ungültiger Name. Namen dürfen nur Buchstaben, Zahlen, Leerzeichen, Apostrophe, Unterstriche und Bindestriche enthalten."
+ },
+ "train": {
+ "title": "Neue Klassifizierungen",
+ "titleShort": "frisch",
+ "aria": "Neue Klassifizierungen auswählen"
+ },
+ "categories": "Klassen",
+ "createCategory": {
+ "new": "Neue Klasse erstellen"
+ },
+ "categorizeImageAs": "Bild klassifizieren als:",
+ "categorizeImage": "Bild klassifizieren",
+ "menu": {
+ "objects": "Objekte",
+ "states": "Zustände"
+ },
+ "noModels": {
+ "object": {
+ "title": "Keine Objektklassifikationsmodelle",
+ "description": "Erstelle ein benutzerdefiniertes Objektklassifikationsmodell, um erkannte Objekte zu klassifizieren.",
+ "buttonText": "Objektklassifikationsmodell erstellen"
+ },
+ "state": {
+ "title": "Keine Zustandsklassifikationsmodelle",
+ "description": "Erstellen Sie ein benutzerdefiniertes Zustandsklassifikationsmodell, um Zustandsänderungen in bestimmten Kamerabereichen zu überwachen und zu klassifizieren.",
+ "buttonText": "Zustandsklassifikationsmodell erstellen"
+ }
+ },
+ "wizard": {
+ "title": "Neues Klassifikationsmodell erstellen",
+ "steps": {
+ "nameAndDefine": "Benennen und definieren",
+ "stateArea": "Überwachungsbereich",
+ "chooseExamples": "Beispiel auswählen"
+ },
+ "step1": {
+ "description": "Zustandsmodelle überwachen fest definierte Kamerabereiche auf Veränderungen (z. B. Tür offen/geschlossen). Objektmodelle klassifizieren erkannte Objekte genauer (z. B. in bekannte Tiere, Lieferanten usw.).",
+ "name": "Name",
+ "namePlaceholder": "Modellname eingeben ...",
+ "type": "Typ",
+ "typeState": "Zustand",
+ "typeObject": "Objekt",
+ "objectLabel": "Objektbezeichnung",
+ "objectLabelPlaceholder": "Auswahl Objekt Typ...",
+ "classificationType": "Klassifizierungstyp",
+ "classificationTypeTip": "Etwas über Klassifizierungstyp lernen",
+ "classificationTypeDesc": "Unterbezeichnungen fügen dem Objektnamen zusätzlichen Text hinzu (z. B. „Person: UPS“). Attribute sind durchsuchbare Metadaten, die separat in den Objektmetadaten gespeichert sind.",
+ "classificationSubLabel": "Unterlabel",
+ "classificationAttribute": "Attribut",
+ "classes": "Klassen",
+ "states": "Zustände",
+ "classesTip": "Mehr über Klassen erfahren",
+ "classesStateDesc": "Definieren Sie die verschiedenen Zustände, in denen sich Ihr Kamerabereich befinden kann. Beispiel: „offen” und „geschlossen” für ein Garagentor.",
+ "classesObjectDesc": "Definieren Sie die verschiedenen Kategorien, in die erkannte Objekte klassifiziert werden sollen. Beispiel: „Lieferant“, „Bewohner“, „Fremder“ für die Klassifizierung von Personen.",
+ "classPlaceholder": "Klassenbezeichnung eingeben...",
+ "errors": {
+ "nameRequired": "Der Modellname ist erforderlich",
+ "nameLength": "Der Modellname darf maximal 64 Zeichen lang sein",
+ "nameOnlyNumbers": "Der Modellname darf nicht nur aus Zahlen bestehen",
+ "classRequired": "Mindestens eine Klasse ist erforderlich",
+ "classesUnique": "Der Klassenname muss eindeutig sein",
+ "stateRequiresTwoClasses": "Zustandsmodelle erfordern mindestens zwei Klassen",
+ "objectLabelRequired": "Bitte wähle eine Objektbeschriftung",
+ "objectTypeRequired": "Bitte wählen Sie einen Klassifizierungstyp aus",
+ "noneNotAllowed": "Die Klasse „none“ ist nicht zulässig"
+ }
+ },
+ "step2": {
+ "description": "Wählen Sie Kameras aus und legen Sie für jede Kamera den zu überwachenden Bereich fest. Das Modell klassifiziert den Zustand dieser Bereiche.",
+ "cameras": "Kameras",
+ "selectCamera": "Kamera auswählen",
+ "noCameras": "Klicke + zum Hinzufügen von Kameras",
+ "selectCameraPrompt": "Wählen Sie eine Kamera aus der Liste aus, um ihren Überwachungsbereich festzulegen"
+ },
+ "step3": {
+ "selectImagesPrompt": "Wählen Sie alle Bilder mit: {{className}}",
+ "selectImagesDescription": "Klicken Sie auf die Bilder, um sie auszuwählen. Klicken Sie auf „Weiter“, wenn Sie mit dieser Klasse fertig sind.",
+ "allImagesRequired_one": "Bitte klassifizieren Sie alle Bilder. {{count}} Bild verbleibend.",
+ "allImagesRequired_other": "Bitte klassifizieren Sie alle Bilder. {{count}} Bilder verbleiben.",
+ "generating": {
+ "title": "Beispielbilder generieren",
+ "description": "Frigate extrahiert repräsentative Bilder aus Ihren Aufnahmen. Dies kann einen Moment dauern..."
+ },
+ "training": {
+ "title": "Trainiere Modell",
+ "description": "Ihr Modell wird im Hintergrund trainiert. Schließen Sie diesen Dialog, und Ihr Modell wird ausgeführt, sobald das Training abgeschlossen ist."
+ },
+ "retryGenerate": "Generierung wiederholen",
+ "noImages": "Keine Bilder generiert",
+ "classifying": "Klassifizieren und Trainieren...",
+ "trainingStarted": "Training wurde erfolgreich gestartet",
+ "errors": {
+ "noCameras": "Keine Kameras konfiguriert",
+ "noObjectLabel": "Kein Objektlabel ausgewählt",
+ "generateFailed": "Beispiele konnten nicht generiert werden: {{error}}",
+ "generationFailed": "Generierung fehlgeschlagen. Bitte versuchen Sie es erneut.",
+ "classifyFailed": "Bilder konnten nicht klassifiziert werden: {{error}}"
+ },
+ "generateSuccess": "Erfolgreich generierte Beispielbilder",
+ "modelCreated": "Modell erfolgreich erstellt. Verwenden Sie die Ansicht „Aktuelle Klassifizierungen“, um Bilder für fehlende Zustände hinzuzufügen und trainieren Sie dann das Modell erneut.",
+ "missingStatesWarning": {
+ "title": "Beispiele für fehlende Zustände",
+ "description": "Es wird empfohlen für alle Zustände Beispiele auszuwählen. Das Modell wird erst trainiert, wenn für alle Zustände Bilder vorhanden sind. Fahren Sie fort und verwenden Sie die Ansicht „Aktuelle Klassifizierungen“, um Bilder für die fehlenden Zustände zu klassifizieren. Trainieren Sie anschließend das Modell."
+ }
+ }
+ },
+ "none": "Keiner"
+}
diff --git a/web/public/locales/de/views/configEditor.json b/web/public/locales/de/views/configEditor.json
index 7f975e31b..86959e126 100644
--- a/web/public/locales/de/views/configEditor.json
+++ b/web/public/locales/de/views/configEditor.json
@@ -12,5 +12,7 @@
}
},
"documentTitle": "Konfigurationseditor – Frigate",
- "confirm": "Verlassen ohne zu Speichern?"
+ "confirm": "Verlassen ohne zu Speichern?",
+ "safeConfigEditor": "Konfiguration Editor (abgesicherter Modus)",
+ "safeModeDescription": "Frigate ist aufgrund eines Konfigurationsvalidierungsfehlers im abgesicherten Modus."
}
diff --git a/web/public/locales/de/views/events.json b/web/public/locales/de/views/events.json
index 2a38ac029..963482073 100644
--- a/web/public/locales/de/views/events.json
+++ b/web/public/locales/de/views/events.json
@@ -8,7 +8,11 @@
"empty": {
"alert": "Es gibt keine zu prüfenden Alarme",
"detection": "Es gibt keine zu prüfenden Erkennungen",
- "motion": "Keine Bewegungsdaten gefunden"
+ "motion": "Keine Bewegungsdaten gefunden",
+ "recordingsDisabled": {
+ "title": "Aufzeichnungen müssen aktiviert sein",
+ "description": "Überprüfungselemente können nur für eine Kamera erstellt werden, wenn Aufzeichnungen für diese Kamera aktiviert sind."
+ }
},
"timeline": "Zeitleiste",
"timeline.aria": "Zeitleiste auswählen",
@@ -34,5 +38,30 @@
"markAsReviewed": "Als geprüft kennzeichnen",
"selected_one": "{{count}} ausgewählt",
"selected_other": "{{count}} ausgewählt",
- "detected": "erkannt"
+ "detected": "erkannt",
+ "suspiciousActivity": "Verdächtige Aktivität",
+ "threateningActivity": "Bedrohliche Aktivität",
+ "zoomIn": "Hereinzoomen",
+ "zoomOut": "Herauszoomen",
+ "detail": {
+ "label": "Detail",
+ "aria": "Detailansicht umschalten",
+ "trackedObject_one": "{{count}} Objekt",
+ "trackedObject_other": "{{count}} Objekte",
+ "noObjectDetailData": "Keine detaillierten Daten des Objekt verfügbar.",
+ "noDataFound": "Keine Detaildaten zur Überprüfung",
+ "settings": "Detailansicht Einstellungen",
+ "alwaysExpandActive": {
+ "desc": "Immer die Objektdetails vom aktivem Überprüfungselement erweitern, sofern verfügbar.",
+ "title": "Immer aktiv erweitern"
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Verfolgter Punkt",
+ "clickToSeek": "Klicke, um zu dieser Zeit zu springen"
+ },
+ "normalActivity": "normal",
+ "needsReview": "benötigt Überprüfung",
+ "securityConcern": "Sicherheitsbedenken",
+ "select_all": "alle"
}
diff --git a/web/public/locales/de/views/explore.json b/web/public/locales/de/views/explore.json
index ee518fc11..273c568a2 100644
--- a/web/public/locales/de/views/explore.json
+++ b/web/public/locales/de/views/explore.json
@@ -17,12 +17,16 @@
"success": {
"updatedSublabel": "Unterkategorie erfolgreich aktualisiert.",
"updatedLPR": "Nummernschild erfolgreich aktualisiert.",
- "regenerate": "Eine neue Beschreibung wurde von {{provider}} angefordert. Je nach Geschwindigkeit des Anbieters kann es einige Zeit dauern, bis die neue Beschreibung generiert ist."
+ "regenerate": "Eine neue Beschreibung wurde von {{provider}} angefordert. Je nach Geschwindigkeit des Anbieters kann es einige Zeit dauern, bis die neue Beschreibung generiert ist.",
+ "audioTranscription": "Die Audio-Transkription wurde erfolgreich angefordert. Je nach Geschwindigkeit Ihres Frigate-Servers kann die Transkription einige Zeit in Anspruch nehmen.",
+ "updatedAttributes": "Attribute erfolgreich aktualisiert."
},
"error": {
"regenerate": "Der Aufruf von {{provider}} für eine neue Beschreibung ist fehlgeschlagen: {{errorMessage}}",
"updatedSublabelFailed": "Untekategorie konnte nicht aktualisiert werden: {{errorMessage}}",
- "updatedLPRFailed": "Aktualisierung des Kennzeichens fehlgeschlagen: {{errorMessage}}"
+ "updatedLPRFailed": "Aktualisierung des Kennzeichens fehlgeschlagen: {{errorMessage}}",
+ "audioTranscription": "Die Anforderung der Audio Transkription ist fehlgeschlagen: {{errorMessage}}",
+ "updatedAttributesFailed": "Attribute konnten nicht aktualisiert werden: {{errorMessage}}"
}
}
},
@@ -55,7 +59,7 @@
},
"description": {
"label": "Beschreibung",
- "placeholder": "Beschreibund des verfolgten Objekts",
+ "placeholder": "Beschreibung des verfolgten Objekts",
"aiTips": "Frigate wird erst dann eine Beschreibung vom generativen KI-Anbieter anfordern, wenn der Lebenszyklus des verfolgten Objekts beendet ist."
},
"expandRegenerationMenu": "Erneuerungsmenü erweitern",
@@ -67,6 +71,17 @@
},
"snapshotScore": {
"label": "Schnappschuss Bewertung"
+ },
+ "score": {
+ "label": "Ergebnis"
+ },
+ "editAttributes": {
+ "title": "Attribute bearbeiten",
+ "desc": "Wählen Sie Klassifizierungsattribute für dieses {{label}} aus"
+ },
+ "attributes": "Klassifizierungsattribute",
+ "title": {
+ "label": "Titel"
}
},
"documentTitle": "Erkunde - Frigate",
@@ -153,7 +168,9 @@
"details": "Details",
"video": "Video",
"object_lifecycle": "Objekt-Lebenszyklus",
- "snapshot": "Snapshot"
+ "snapshot": "Snapshot",
+ "thumbnail": "Vorschaubild",
+ "tracking_details": "Nachverfolgungs-Details"
},
"itemMenu": {
"downloadSnapshot": {
@@ -182,12 +199,34 @@
},
"deleteTrackedObject": {
"label": "Dieses verfolgte Objekt löschen"
+ },
+ "audioTranscription": {
+ "aria": "Audio Transkription anfordern",
+ "label": "Transkribieren"
+ },
+ "addTrigger": {
+ "aria": "Einen Trigger für dieses verfolgte Objekt hinzufügen",
+ "label": "Trigger hinzufügen"
+ },
+ "viewTrackingDetails": {
+ "label": "Details zum Verfolgen anzeigen",
+ "aria": "Details zum Verfolgen anzeigen"
+ },
+ "showObjectDetails": {
+ "label": "Objektpfad anzeigen"
+ },
+ "hideObjectDetails": {
+ "label": "Objektpfad verbergen"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Bereinigte Momentaufnahme herunterladen",
+ "aria": "Bereinigte Momentaufnahme herunterladen"
}
},
"dialog": {
"confirmDelete": {
"title": "Löschen bestätigen",
- "desc": "Beim Löschen dieses verfolgten Objekts werden der Schnappschuss, alle gespeicherten Einbettungen und alle zugehörigen Objektlebenszykluseinträge entfernt. Aufgezeichnetes Filmmaterial dieses verfolgten Objekts in der Verlaufsansicht wird NICHT gelöscht. Pfade
Linien und Kreise zeigen wichtige Punkte an, an denen sich das verfolgte Objekt während seines Lebenszyklus bewegt hat.
" + }, + "openCameraWebUI": "Web-Benutzeroberfläche von {{camera}} öffnen", + "audio": { + "title": "Audio", + "noAudioDetections": "Keine Audioerkennungen", + "score": "Punktzahl", + "currentRMS": "Aktueller Effektivwert", + "currentdbFS": "Aktuelle dbFS" + } }, "motionDetectionTuner": { "Threshold": { @@ -420,11 +486,11 @@ "desc": "Der Wert für die Konturfläche wird verwendet, um zu bestimmen, welche Gruppen von veränderten Pixeln als Bewegung gelten. Standard: 10" }, "title": "Bewegungserkennungs-Optimierer", - "unsavedChanges": "Nicht gespeicherte Änderungen am Bewegungstuner ({{camera}})" + "unsavedChanges": "Nicht gespeicherte Änderungen im Bewegungserkennungs-Optimierer ({{camera}})" }, "users": { "addUser": "Benutzer hinzufügen", - "updatePassword": "Passwort aktualisieren", + "updatePassword": "Passwort zurücksetzen", "toast": { "success": { "deleteUser": "Benutzer {{user}} wurde erfolgreich gelöscht", @@ -448,7 +514,7 @@ "changeRole": "Benutzerrolle ändern", "deleteUser": "Benutzer löschen", "noUsers": "Keine Benutzer gefunden.", - "password": "Passwort", + "password": "Passwort zurücksetzen", "username": "Benutzername", "actions": "Aktionen", "role": "Rolle" @@ -475,7 +541,16 @@ }, "match": "Passwörter stimmen überein", "title": "Passwort", - "placeholder": "Passwort eingeben" + "placeholder": "Passwort eingeben", + "requirements": { + "title": "Passwort Anforderungen:", + "length": "Mindestens 12 Zeichen", + "uppercase": "Mindestens ein Großbuchstabe", + "digit": "Mindestens eine Ziffer", + "special": "Mindestens ein Sonderzeichen (!@#$%^&*(),.?\":{}|<>)" + }, + "show": "Passwort anzeigen", + "hide": "Verberge Passwort" }, "newPassword": { "title": "Neues Passwort", @@ -485,7 +560,11 @@ } }, "usernameIsRequired": "Benutzername ist erforderlich", - "passwordIsRequired": "Passwort benötigt" + "passwordIsRequired": "Passwort benötigt", + "currentPassword": { + "title": "Aktuelles Passwort", + "placeholder": "Gib Dein aktuelles Passwort ein" + } }, "changeRole": { "desc": "Berechtigungen für {{username}} aktualisieren", @@ -494,7 +573,8 @@ "admin": "Admin", "adminDesc": "Voller Zugang zu allen Funktionen.", "viewer": "Betrachter", - "viewerDesc": "Nur auf Live-Dashboards, Überprüfung, Erkundung und Exporte beschränkt." + "viewerDesc": "Nur auf Live-Dashboards, Überprüfung, Erkundung und Exporte beschränkt.", + "customDesc": "Benutzerdefinierte Rolle mit spezifischem Kamerazugriff." }, "title": "Benutzerrolle ändern", "select": "Wähle eine Rolle" @@ -515,7 +595,12 @@ "setPassword": "Passwort festlegen", "desc": "Erstelle ein sicheres Passwort, um dieses Konto zu schützen.", "cannotBeEmpty": "Das Passwort darf nicht leer sein", - "doNotMatch": "Die Passwörter sind nicht identisch" + "doNotMatch": "Die Passwörter sind nicht identisch", + "currentPasswordRequired": "Aktuelles Passwort wird benötigt", + "incorrectCurrentPassword": "Aktuelles Passwort ist falsch", + "passwordVerificationFailed": "Passwort konnte nicht überprüft werden", + "multiDeviceWarning": "Alle anderen Geräte, auf denen Sie angemeldet sind, müssen sich innerhalb von {{refresh_time}} erneut anmelden.", + "multiDeviceAdmin": "Sie können auch alle Benutzer dazu zwingen, sich sofort erneut zu authentifizieren, indem Sie Ihr JWT-Geheimnis ändern." } } }, @@ -620,21 +705,21 @@ }, "enrichments": { "birdClassification": { - "title": "Vogel Klassifizierung", - "desc": "Die Vogelklassifizierung identifiziert bekannte Vögel mithilfe eines quantisierten Tensorflow-Modells. Wenn ein bekannter Vogel erkannt wird, wird sein allgemeiner Name als sub_label hinzugefügt. Diese Informationen sind in der Benutzeroberfläche, in Filtern und in Benachrichtigungen enthalten." + "title": "Vogelerkennung", + "desc": "Die Vogelerkennung identifiziert Vögelarten mithilfe eines quantisierten Tensorflowmodells. Wenn eine Vogelart erkannt wird, wird ihr Name als sub_label hinzugefügt. Diese Informationen sind in der Benutzeroberfläche, in Filtern und in Benachrichtigungen enthalten." }, "title": "Anreicherungseinstellungen", "unsavedChanges": "Ungesicherte geänderte Verbesserungseinstellungen", "semanticSearch": { "reindexNow": { "confirmDesc": "Sind Sie sicher, dass Sie alle verfolgten Objekteinbettungen neu indizieren wollen? Dieser Prozess läuft im Hintergrund, kann aber Ihre CPU auslasten und eine gewisse Zeit in Anspruch nehmen. Sie können den Fortschritt auf der Seite Explore verfolgen.", - "label": "Jetzt neu indizien", + "label": "Jetzt neu indizieren", "desc": "Bei der Neuindizierung werden die Einbettungen für alle verfolgten Objekte neu generiert. Dieser Prozess läuft im Hintergrund und kann je nach Anzahl der verfolgten Objekte Ihre CPU auslasten und eine gewisse Zeit in Anspruch nehmen.", - "confirmTitle": "Neuinszenierung bestätigen", + "confirmTitle": "Neuindizierung bestätigen", "confirmButton": "Neuindizierung", "success": "Die Neuindizierung wurde erfolgreich gestartet.", "alreadyInProgress": "Die Neuindizierung ist bereits im Gange.", - "error": "Neuindizierung konnte nicht gestartet werden: {{errorMessage}}" + "error": "Die Neuindizierung konnte nicht gestartet werden: {{errorMessage}}" }, "modelSize": { "small": { @@ -645,7 +730,7 @@ "desc": "Die Größe des für die Einbettung der semantischen Suche verwendeten Modells.", "large": { "title": "groß", - "desc": "Bei der Verwendung von groß wird das gesamte Jina-Modell verwendet und automatisch auf der GPU ausgeführt, falls zutreffend." + "desc": "Bei der Verwendung von groß wird das gesamte Jina-Modell verwendet und automatisch auf der GPU ausgeführt, falls möglich." } }, "title": "Semantische Suche", @@ -654,10 +739,10 @@ }, "faceRecognition": { "title": "Gesichtserkennung", - "desc": "Die Gesichtserkennung ermöglicht es, Personen Namen zuzuweisen, und wenn ihr Gesicht erkannt wird, ordnet Frigate den Namen der Person als Untertitel zu. Diese Informationen sind in der Benutzeroberfläche, den Filtern und in den Benachrichtigungen enthalten.", + "desc": "Die Gesichtserkennung ermöglicht es, Personen Namen zuzuweisen. Wenn ein Gesicht erkannt wird, ordnet Frigate den Namen der Person als Untertitel zu. Diese Informationen sind in der Benutzeroberfläche, den Filtern und in den Benachrichtigungen enthalten.", "readTheDocumentation": "Lies die Dokumentation", "modelSize": { - "label": "Modell Größe", + "label": "Modellgröße", "desc": "Die Größe des für die Gesichtserkennung verwendeten Modells.", "small": { "title": "klein", @@ -679,5 +764,538 @@ "success": "Die Einstellungen für die Verbesserungen wurden gespeichert. Starten Sie Frigate neu, um Ihre Änderungen zu übernehmen.", "error": "Konfigurationsänderungen konnten nicht gespeichert werden: {{errorMessage}}" } + }, + "triggers": { + "documentTitle": "Auslöser", + "management": { + "title": "Auslöser", + "desc": "Auslöser für {{camera}} verwalten. Verwenden Sie den Vorschaubild Typ, um ähnliche Vorschaubilder wie das ausgewählte verfolgte Objekt auszulösen, und den Beschreibungstyp, um ähnliche Beschreibungen wie den von Ihnen angegebenen Text auszulösen." + }, + "addTrigger": "Auslöser hinzufügen", + "table": { + "name": "Name", + "type": "Typ", + "content": "Inhalt", + "threshold": "Schwellenwert", + "actions": "Aktionen", + "noTriggers": "Für diese Kamera sind keine Auslöser konfiguriert.", + "edit": "Bearbeiten", + "deleteTrigger": "Auslöser löschen", + "lastTriggered": "Zuletzt ausgelöst" + }, + "type": { + "thumbnail": "Vorschaubild", + "description": "Beschreibung" + }, + "actions": { + "alert": "Als Alarm markieren", + "notification": "Benachrichtigung senden", + "sub_label": "Unterlabel hinzufügen", + "attribute": "Attribut hinzufügen" + }, + "dialog": { + "createTrigger": { + "title": "Auslöser erstellen", + "desc": "Auslöser für Kamera {{camera}} erstellen" + }, + "editTrigger": { + "title": "Auslöser bearbeiten", + "desc": "Einstellungen für Kamera {{camera}} bearbeiten" + }, + "deleteTrigger": { + "title": "Auslöser löschen", + "desc": "Sind Sie sicher, dass Sie den Auslöser {{triggerName}} löschen wollen? Dies kann nicht Rückgängig gemacht werden." + }, + "form": { + "name": { + "title": "Name", + "placeholder": "Benennen Sie diesen Auslöser", + "error": { + "minLength": "Der Name muss mindestens 2 Zeichen lang sein.", + "invalidCharacters": "Der Name darf nur Buchstaben, Zahlen, Unterstriche und Bindestriche enthalten.", + "alreadyExists": "Ein Auslöser mit diesem Namen existiert bereits für diese Kamera." + }, + "description": "Geben Sie einen eindeutigen Namen oder eine Beschreibung ein, um diesen Auslöser zu identifizieren" + }, + "enabled": { + "description": "Diesen Auslöser aktivieren oder deaktivieren" + }, + "type": { + "title": "Typ", + "placeholder": "Auslöser Typ wählen", + "description": "Auslösen, wenn eine ähnliche Beschreibung eines verfolgten Objekts erkannt wird", + "thumbnail": "Auslösen, wenn eine ähnliche Miniaturansicht eines verfolgten Objekts erkannt wird" + }, + "content": { + "title": "Inhalt", + "imagePlaceholder": "Miniaturansicht auswählen", + "textPlaceholder": "Inhaltstext eingeben", + "imageDesc": "Es werden nur die letzten 100 Miniaturansichten angezeigt. Wenn Sie die gewünschte Miniaturansicht nicht finden können, überprüfen Sie bitte frühere Objekte in „Explore“ und richten Sie dort über das Menü einen Trigger ein.", + "textDesc": "Einen Text eingeben, um diese Aktion auszulösen, wenn eine ähnliche Beschreibung eines verfolgten Objekts erkannt wird.", + "error": { + "required": "Inhalt ist erforderlich." + } + }, + "threshold": { + "title": "Schwellenwert", + "error": { + "min": "Schwellenwert muss mindestens 0 sein", + "max": "Schwellenwert darf höchstens 1 sein" + }, + "desc": "Legen Sie den Ähnlichkeitsschwellenwert für diesen Trigger fest. Ein höherer Schwellenwert bedeutet, dass eine größere Übereinstimmung erforderlich ist, um den Trigger auszulösen." + }, + "actions": { + "title": "Aktionen", + "desc": "Standardmäßig sendet Frigate für alle Trigger eine MQTT-Nachricht. Unterbezeichnungen fügen den Triggernamen zur Objektbezeichnung hinzu. Attribute sind durchsuchbare Metadaten, die separat in den Metadaten des verfolgten Objekts gespeichert werden.", + "error": { + "min": "Mindesten eine Aktion muss ausgewählt sein." + } + }, + "friendly_name": { + "title": "Nutzerfreundlicher Name", + "placeholder": "Benenne oder beschreibe diesen Auslöser", + "description": "Ein optionaler nutzerfreundlicher Name oder eine Beschreibung für diesen Auslöser." + } + } + }, + "toast": { + "success": { + "createTrigger": "Auslöser {{name}} erfolgreich erstellt.", + "updateTrigger": "Auslöser {{name}} erfolgreich aktualisiert.", + "deleteTrigger": "Auslöser {{name}} erfolgreich gelöscht." + }, + "error": { + "createTriggerFailed": "Auslöser konnte nicht erstellt werden: {{errorMessage}}", + "updateTriggerFailed": "Auslöser könnte nicht aktualisiert werden: {{errorMessage}}", + "deleteTriggerFailed": "Auslöser konnte nicht gelöscht werden: {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "Semantische Suche ist deaktiviert", + "desc": "Semantische Suche muss aktiviert sein um Auslöser nutzen zu können." + }, + "wizard": { + "title": "Auslöser erstellen", + "step1": { + "description": "Konfigurieren Sie die Grundeinstellungen für Ihren Auslöser." + }, + "step2": { + "description": "Legen Sie den Inhalt fest, der diese Aktion auslöst." + }, + "step3": { + "description": "Konfigurieren Sie den Schwellenwert und die Aktionen für diesen Trigger." + }, + "steps": { + "nameAndType": "Name und Typ", + "configureData": "Daten konfigurieren", + "thresholdAndActions": "Schwellenwert und Maßnahmen" + } + } + }, + "roles": { + "dialog": { + "form": { + "cameras": { + "required": "Mindestens eine Kamera muss ausgewählt werden.", + "title": "Kameras", + "desc": "Wählen Sie die Kameras aus, auf die diese Rolle Zugriff hat. Mindestens eine Kamera ist erforderlich." + }, + "role": { + "title": "Rolle Name", + "placeholder": "Rollen Name eingeben", + "desc": "Es sind nur Buchstaben, Zahlen, Punkte und Unterstriche zulässig.", + "roleIsRequired": "Rollen Name ist erforderlich", + "roleOnlyInclude": "Der Rollenname darf nur Buchstaben, Zahlen, . oder _ enthalten", + "roleExists": "Eine Rolle mit diesem Namen existiert bereits." + } + }, + "createRole": { + "title": "Neue Rolle erstellen", + "desc": "Fügen Sie eine neue Rolle hinzu und legen Sie die Berechtigungen für den Kamerazugriff fest." + }, + "editCameras": { + "title": "Rollenkameras bearbeiten", + "desc": "Aktualisieren Sie den Kamerazugriff für die Rolle {{role}}." + }, + "deleteRole": { + "title": "Rolle löschen", + "desc": "Diese Aktion kann nicht rückgängig gemacht werden. Dadurch wird die Rolle dauerhaft gelöscht und allen Benutzern mit dieser Rolle die Rolle „Betrachter“ zugewiesen, die dann Zugriff auf alle Kameras erhält.", + "warn": "Möchten Sie {{role}} wirklich löschen?", + "deleting": "Lösche..." + } + }, + "management": { + "title": "Zuschauer Rollenverwaltung", + "desc": "Verwalten Sie benutzerdefinierte Zuschauerrollen und ihre Kamerazugriffsberechtigungen für diese Frigate-Instanz." + }, + "addRole": "Rolle hinzufügen", + "table": { + "role": "Rolle", + "cameras": "Kameras", + "actions": "Aktionen", + "noRoles": "Keine benutzerdefinierten Rollen gefunden.", + "editCameras": "Kameras bearbeiten", + "deleteRole": "Rolle löschen" + }, + "toast": { + "success": { + "createRole": "Rolle {{role}} erfolgreich erstellt", + "updateCameras": "Kameras für Rolle {{role}} aktualisiert", + "deleteRole": "Rolle {{role}} erfolgreich gelöscht", + "userRolesUpdated_one": "{{count}} Benutzer, denen diese Rolle zugewiesen wurde, wurden auf „Zuschauer“ aktualisiert, der Zugriff auf alle Kameras hat.", + "userRolesUpdated_other": "{{count}} Benutzer, denen diese Rollen zugewiesen wurde, wurden auf „Zuschauer“ aktualisiert, der Zugriff auf alle Kameras habem." + }, + "error": { + "createRoleFailed": "Fehler beim Erstellen der Rolle: {{errorMessage}}", + "updateCamerasFailed": "Aktualisierung der Kameras fehlgeschlagen: {{errorMessage}}", + "deleteRoleFailed": "Rolle konnte nicht gelöscht werden: {{errorMessage}}", + "userUpdateFailed": "Aktualisierung der Benutzerrollen fehlgeschlagen: {{errorMessage}}" + } + } + }, + "cameraWizard": { + "title": "Kamera hinzufügen", + "description": "Folge den Anweisungen unten, um eine neue Kamera zu deiner Frigate-Installation hinzuzufügen.", + "steps": { + "nameAndConnection": "Name & Verbindung", + "streamConfiguration": "Stream Konfiguration", + "validationAndTesting": "Überprüfung & Testen", + "probeOrSnapshot": "Test oder Momentaufnahme" + }, + "save": { + "success": "Neue Kamera {{cameraName}} erfolgreich hinzugefügt.", + "failure": "Fehler beim Speichern von {{cameraName}}." + }, + "testResultLabels": { + "resolution": "Auflösung", + "video": "Video", + "audio": "Audio", + "fps": "FPS" + }, + "commonErrors": { + "noUrl": "Bitte korrekte Stream-URL eingeben", + "testFailed": "Stream Test fehlgeschlagen: {{error}}" + }, + "step1": { + "description": "Geben Sie Ihre Kameradaten ein und wählen Sie, ob Sie die Kamera automatisch erkennen lassen oder die Marke manuell auswählen möchten.", + "cameraName": "Kameraname", + "cameraNamePlaceholder": "z.B. vordere_tür oder Hof Übersicht", + "host": "Host/IP Adresse", + "port": "Port", + "username": "Nutzername", + "usernamePlaceholder": "Optional", + "password": "Passwort", + "passwordPlaceholder": "Optional", + "selectTransport": "Transport-Protokoll auswählen", + "cameraBrand": "Kamerahersteller", + "selectBrand": "Wähle die Kamerahersteller für die URL-Vorlage aus", + "customUrl": "Benutzerdefinierte Stream-URL", + "brandInformation": "Hersteller Information", + "brandUrlFormat": "Für Kameras mit RTSP URL nutze folgendes Format: {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://nutzername:passwort@host:port/pfad", + "testConnection": "Teste Verbindung", + "testSuccess": "Verbindungstest erfolgreich!", + "testFailed": "Verbindungstest fehlgeschlagen. Bitte prüfe deine Eingaben und versuche es erneut.", + "streamDetails": "Stream Details", + "warnings": { + "noSnapshot": "Es kann kein Snapshot aus dem konfigurierten Stream abgerufen werden." + }, + "errors": { + "brandOrCustomUrlRequired": "Wählen Sie entweder einen Kamerahersteller mit Host/IP aus oder wählen Sie „Andere“ mit einer benutzerdefinierten URL", + "nameRequired": "Der Kameraname wird benötigt", + "nameLength": "Der Kameraname darf höchsten 64 Zeichen lang sein", + "invalidCharacters": "Der Kameraname enthält ungültige Zeichen", + "nameExists": "Der Kameraname existiert bereits", + "brands": { + "reolink-rtsp": "Reolink RTSP wird nicht empfohlen. Es wird empfohlen, http in den Kameraeinstellungen zu aktivieren und den Kamera-Assistenten neu zu starten." + }, + "customUrlRtspRequired": "Benutzerdefinierte URLs müssen mit „rtsp://“ beginnen. Für Nicht-RTSP-Kamerastreams ist eine manuelle Konfiguration erforderlich." + }, + "docs": { + "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras" + }, + "connectionSettings": "Verbindungseinstellungen", + "detectionMethod": "Stream Erkennungsmethode", + "onvifPort": "ONVIF Port", + "probeMode": "Untersuche Kamera", + "detectionMethodDescription": "Suchen Sie die Kamera mit ONVIF (sofern unterstützt), um die URLs der Kamerastreams zu finden, oder wählen Sie manuell die Kameramarke aus, um vordefinierte URLs zu verwenden. Um eine benutzerdefinierte RTSP-URL einzugeben, wählen Sie die manuelle Methode und dann „Andere“.", + "onvifPortDescription": "Bei Kameras, die ONVIF unterstützen, ist dies in der Regel 80 oder 8080.", + "useDigestAuth": "Digest-Authentifizierung verwenden", + "useDigestAuthDescription": "Verwenden Sie die HTTP-Digest-Authentifizierung für ONVIF. Einige Kameras erfordern möglicherweise einen speziellen ONVIF-Benutzernamen/ein spezielles ONVIF-Passwort anstelle des Standard-Admin-Benutzers.", + "manualMode": "Manuelle Auswahl" + }, + "step2": { + "description": "Suchen Sie in der Kamera nach verfügbaren Streams oder konfigurieren Sie manuelle Einstellungen basierend auf der von Ihnen ausgewählten Erkennungsmethode.", + "streamsTitle": "Kamera Streams", + "addStream": "Stream hinzufügen", + "addAnotherStream": "Weiteren Stream hinzufügen", + "streamTitle": "Stream {{nummer}}", + "streamUrl": "Stream URL", + "streamUrlPlaceholder": "rtsp://nutzername:passwort@host:port/pfad", + "url": "URL", + "resolution": "Auflösung", + "selectResolution": "Auflösung auswählen", + "quality": "Qualität", + "selectQuality": "Qualität auswählen", + "roles": "Rollen", + "roleLabels": { + "detect": "Objekt-Erkennung", + "record": "Aufzeichnung", + "audio": "Audio" + }, + "testStream": "Verbindung testen", + "testSuccess": "Verbindung erfolgreich getestet!", + "testFailed": "Verbindungstest fehlgeschlagen. Bitte überprüfen Sie ihre Eingaben und versuchen Sie es erneut.", + "testFailedTitle": "Test fehlgeschlagen", + "connected": "Verbunden", + "notConnected": "Nicht verbunden", + "featuresTitle": "Funktionen", + "go2rtc": "Verbindungen zur Kamera reduzieren", + "detectRoleWarning": "Mindestens ein Stream muss die Rolle „detect“ haben, um fortfahren zu können.", + "rolesPopover": { + "title": "Stream Rollen", + "detect": "Haupt-Feed für Objekt-Erkennung.", + "record": "Speichert Segmente des Video-Feeds basierend auf den Konfigurationseinstellungen.", + "audio": "Feed für audiobasierte Erkennung." + }, + "featuresPopover": { + "title": "Stream Funktionen", + "description": "Verwende go2rtc Restreaming, um die Verbindungen zu deiner Kamera zu reduzieren." + }, + "streamDetails": "Verbindungsdetails", + "probing": "Kamera wird geprüft...", + "retry": "Wiederholen", + "testing": { + "probingMetadata": "Metadaten der Kamera werden überprüft...", + "fetchingSnapshot": "Kamera-Schnappschuss wird abgerufen..." + }, + "probeFailed": "Fehler beim Untersuchen der Kamera: {{error}}", + "probingDevice": "Untersuche Gerät...", + "probeSuccessful": "Erkennung erfolgreich", + "probeError": "Erkennungsfehler", + "probeNoSuccess": "Erkennung fehlgeschlagen", + "deviceInfo": "Geräteinformationen", + "manufacturer": "Hersteller", + "model": "Modell", + "firmware": "Firmware", + "profiles": "Profile", + "ptzSupport": "PTZ Unterstützung", + "autotrackingSupport": "Unterstützung für Autoverfolgung", + "presets": "Voreinstellung", + "rtspCandidates": "RTSP Kandidaten", + "rtspCandidatesDescription": "Die folgenden RTSP-URLs wurden bei der Kameraerkennung gefunden. Testen Sie die Verbindung, um die Stream-Metadaten anzuzeigen.", + "noRtspCandidates": "Es wurden keine RTSP-URLs von der Kamera gefunden. Möglicherweise sind Ihre Anmeldedaten falsch oder die Kamera unterstützt ONVIF oder die Methode zum Abrufen von RTSP-URLs nicht. Gehen Sie zurück und geben Sie die RTSP-URL manuell ein.", + "candidateStreamTitle": "Kandidate {{number}}", + "useCandidate": "Verwenden", + "uriCopy": "Kopieren", + "uriCopied": "URI in die Zwischenablage kopiert", + "testConnection": "Test Verbindung", + "toggleUriView": "Klicken Sie hier, um die vollständige URI zu sehen", + "errors": { + "hostRequired": "Host/IP adresse wird benötigt" + } + }, + "step3": { + "description": "Konfigurieren Sie Stream-Rollen und fügen Sie zusätzliche Streams für Ihre Kamera hinzu.", + "validationTitle": "Stream Validierung", + "connectAllStreams": "Verbinde alle Streams", + "reconnectionSuccess": "Wiederverbindung erfolgreich.", + "reconnectionPartial": "Einige Streams konnten nicht wieder verbunden werden.", + "streamUnavailable": "Stream-Vorschau nicht verfügbar", + "reload": "Neu laden", + "connecting": "Verbinde...", + "streamTitle": "Stream {{number}}", + "valid": "Gültig", + "failed": "Fehlgeschlagen", + "notTested": "Nicht getestet", + "connectStream": "Verbinden", + "connectingStream": "Verbinde", + "disconnectStream": "Trennen", + "estimatedBandwidth": "Geschätzte Bandbreite", + "roles": "Rollen", + "none": "Keine", + "error": "Fehler", + "streamValidated": "Stream {{number}} wurde erfolgreich validiert", + "streamValidationFailed": "Stream {{number}} Validierung fehlgeschlagen", + "saveAndApply": "Neue Kamera speichern", + "saveError": "Ungültige Konfiguration. Bitte prüfe die Einstellungen.", + "issues": { + "title": "Stream Validierung", + "videoCodecGood": "Video-Codec ist {{codec}}.", + "audioCodecGood": "Audio-Codec ist {{codec}}.", + "noAudioWarning": "Für diesen Stream wurde kein Ton erkannt, die Aufzeichnungen enthalten keinen Ton.", + "audioCodecRecordError": "Der AAC-Audio-Codec ist erforderlich, um Audio in Aufnahmen zu unterstützen.", + "audioCodecRequired": "Ein Audiostream ist erforderlich, um Audioerkennung zu unterstützen.", + "restreamingWarning": "Eine Reduzierung der Verbindungen zur Kamera für den Aufzeichnungsstream kann zu einer etwas höheren CPU-Auslastung führen.", + "dahua": { + "substreamWarning": "Substream 1 ist auf eine niedrige Auflösung festgelegt. Viele Kameras von Dahua / Amcrest / EmpireTech unterstützen zusätzliche Substreams, die in den Kameraeinstellungen aktiviert werden müssen. Es wird empfohlen, diese Streams zu nutzen, sofern sie verfügbar sind." + }, + "hikvision": { + "substreamWarning": "Substream 1 ist auf eine niedrige Auflösung festgelegt. Viele Hikvision-Kameras unterstützen zusätzliche Substreams, die in den Kameraeinstellungen aktiviert werden müssen. Es wird empfohlen, diese Streams zu nutzen, sofern sie verfügbar sind." + } + }, + "streamsTitle": "Kamera Stream", + "addStream": "Stream hinzufügen", + "addAnotherStream": "weiteren Stream hinzufügen", + "streamUrl": "Stream URL", + "streamUrlPlaceholder": "rtsp://benutzername:passwort@host:port/path", + "selectStream": "Auswahl Stream", + "searchCandidates": "Suche Kandidaten...", + "noStreamFound": "Kein Stream gefunden", + "url": "URL", + "resolution": "Auflösung", + "selectResolution": "Wähle Auflösung", + "quality": "Qualität", + "selectQuality": "Wähle Qualität", + "roleLabels": { + "detect": "Objekterkennung", + "record": "Aufnahme", + "audio": "Ton" + }, + "testStream": "Verbindungstest", + "testSuccess": "Verbindungstest erfolgreich!", + "testFailed": "Verbindungstest fehlgeschlagen", + "testFailedTitle": "Test fehlgeschlagen", + "connected": "Verbunden", + "notConnected": "nicht verbunden", + "featuresTitle": "Funktionen", + "go2rtc": "Verbindungen zur Kamera reduzieren", + "detectRoleWarning": "Mindestens ein Stream muss die Rolle „detect“ haben, um fortfahren zu können.", + "rolesPopover": { + "title": "Stream Rollen", + "detect": "Hauptfeed für die Objekterkennung.", + "record": "Speichert Segmente des Video-Feeds basierend auf den Konfigurationseinstellungen.", + "audio": "Feed für audiobasierte Erkennung." + }, + "featuresPopover": { + "title": "Stream Funktionen", + "description": "Verwenden Sie go2rtc-Restreaming, um die Verbindungen zu Ihrer Kamera zu reduzieren." + } + }, + "step4": { + "description": "Endgültige Validierung und Analyse vor dem Speichern Ihrer neuen Kamera. Verbinden Sie jeden Stream vor dem Speichern.", + "validationTitle": "Stream-Validierung", + "connectAllStreams": "Alle Streams verbinden", + "reconnectionSuccess": "Wiederverbindung erfolgreich.", + "reconnectionPartial": "Einige Streams konnten nicht wieder verbunden werden.", + "streamUnavailable": "Stream Vorschau nicht verfügbar", + "reload": "neu Laden", + "connecting": "Verbinden...", + "streamTitle": "Stream {{number}}", + "valid": "gültig", + "failed": "fehlgeschlagen", + "notTested": "nicht getestet", + "connectStream": "Verbinden", + "connectingStream": "Verbinden", + "disconnectStream": "getrennt", + "estimatedBandwidth": "Voraussichtliche Bandbreite", + "roles": "Rollen", + "ffmpegModule": "Stream-Kompatibilitätsmodus verwenden", + "ffmpegModuleDescription": "Wenn der Stream nach mehreren Versuchen nicht geladen wird, versuchen Sie, diese Option zu aktivieren. Wenn diese Option aktiviert ist, verwendet Frigate das ffmpeg-Modul mit go2rtc. Dies kann zu einer besseren Kompatibilität mit einigen Kamerastreams führen.", + "none": "keiner", + "error": "Fehler", + "streamValidated": "Steam {{number}} erfolgreich validiert", + "streamValidationFailed": "Stream {{number}} Validierung fehlgeschlagen", + "saveAndApply": "Neue Kamera speichern", + "saveError": "Ungültige Konfiguration. Bitte überprüfen Sie Ihre Einstellungen.", + "issues": { + "title": "Stream-Validierung", + "videoCodecGood": "Video codec ist {{codec}}.", + "audioCodecGood": "Audio codec ist {{codec}}.", + "resolutionHigh": "Eine Auflösung von {{resolution}} kann zu einem erhöhten Ressourcenverbrauch führen.", + "resolutionLow": "Eine Auflösung von {{resolution}} ist möglicherweise zu gering, um kleine Objekte zuverlässig zu erkennen.", + "noAudioWarning": "Für diesen Stream wurde kein Ton erkannt, die Aufzeichnungen enthalten keinen Ton.", + "audioCodecRecordError": "Der AAC-Audio-Codec ist erforderlich, um Audio in Aufnahmen zu unterstützen.", + "audioCodecRequired": "Ein Audiostream ist erforderlich, um die Audioerkennung zu unterstützen.", + "restreamingWarning": "Die Reduzierung der Verbindungen zur Kamera für den Aufzeichnungsstream kann zu einer geringfügigen Erhöhung der CPU-Auslastung führen.", + "brands": { + "reolink-rtsp": "Reolink RTSP wird nicht empfohlen. Aktivieren Sie HTTP in den Firmware-Einstellungen der Kamera und starten Sie den Assistenten neu.", + "reolink-http": "Für Reolink-HTTP-Streams sollten sie FFmpeg verwenden, um eine bessere Kompatibilität zu gewährleisten. Aktivieren Sie für diesen Stream die Option „Stream-Kompatibilitätsmodus verwenden“." + }, + "dahua": { + "substreamWarning": "Substream 1 ist auf eine niedrige Auflösung festgelegt. Viele Kameras von Dahua / Amcrest / EmpireTech unterstützen zusätzliche Substreams, die in den Kameraeinstellungen aktiviert werden müssen. Es wird empfohlen, diese Streams zu überprüfen und zu nutzen, sofern sie verfügbar sind." + }, + "hikvision": { + "substreamWarning": "Substream 1 ist auf eine niedrige Auflösung festgelegt. Viele Hikvision-Kameras unterstützen zusätzliche Substreams, die in den Kameraeinstellungen aktiviert werden müssen. Es wird empfohlen, diese Streams zu überprüfen und zu nutzen, sofern sie verfügbar sind." + } + } + } + }, + "cameraManagement": { + "title": "Kameras verwalten", + "addCamera": "Neue Kamera hinzufügen", + "editCamera": "Kamera bearbeiten:", + "selectCamera": "Wähle eine Kamera", + "backToSettings": "Zurück zu Kameraeinstellungen", + "streams": { + "title": "Kameras aktivieren / deaktivieren", + "desc": "Deaktiviere eine Kamera vorübergehend, bis Frigate neu gestartet wird. Deaktivierung einer Kamera stoppt die Verarbeitung der Streams dieser Kamera durch Frigate vollständig. Erkennung, Aufzeichnung und Debugging sind dann nicht mehr verfügbar.ffprobe erhalten.",
"tips": {
"title": "Kamera-Untersuchsungsinfo"
@@ -162,10 +179,20 @@
"face_recognition": "Gesichts Erkennung",
"image_embedding": "Bild Embedding",
"yolov9_plate_detection_speed": "YOLOv9 Kennzeichenerkennungsgeschwindigkeit",
- "yolov9_plate_detection": "YOLOv9 Kennzeichenerkennung"
+ "yolov9_plate_detection": "YOLOv9 Kennzeichenerkennung",
+ "review_description": "Bewertung Beschreibung",
+ "review_description_speed": "Bewertungsbeschreibung Geschwindigkeit",
+ "review_description_events_per_second": "Bewertungsbeschreibung",
+ "object_description": "Objekt Beschreibung",
+ "object_description_speed": "Objektbeschreibung Geschwindigkeit",
+ "object_description_events_per_second": "Objektbeschreibung",
+ "classification": "{{name}} Klassifizierung",
+ "classification_speed": "{{name}} Klassifizierungsgeschwindigkeit",
+ "classification_events_per_second": "{{name}} Klassifizierungsereignisse pro Sekunde"
},
"title": "Optimierungen",
- "infPerSecond": "Rückschlüsse pro Sekunde"
+ "infPerSecond": "Rückschlüsse pro Sekunde",
+ "averageInf": "Durchschnittliche Inferenzzeit"
},
"stats": {
"healthy": "Das System läuft problemlos",
@@ -174,7 +201,8 @@
"reindexingEmbeddings": "Neuindizierung von Einbettungen ({{processed}}% erledigt)",
"detectIsSlow": "{{detect}} ist langsam ({{speed}} ms)",
"detectIsVerySlow": "{{detect}} ist sehr langsam ({{speed}} ms)",
- "cameraIsOffline": "{{camera}} ist offline"
+ "cameraIsOffline": "{{camera}} ist offline",
+ "shmTooLow": "Die Zuweisung für /dev/shm ({{total}} MB) sollte auf mindestens {{min}} MB erhöht werden."
},
"lastRefreshed": "Zuletzt aktualisiert: "
}
diff --git a/web/public/locales/el/audio.json b/web/public/locales/el/audio.json
index f8dfffbc8..2bd01b871 100644
--- a/web/public/locales/el/audio.json
+++ b/web/public/locales/el/audio.json
@@ -48,5 +48,18 @@
"acoustic_guitar": "Ακουστική Κιθάρα",
"classical_music": "Κλασική Μουσική",
"opera": "Όπερα",
- "electronic_music": "Ηλεκτρονική Μουσική"
+ "electronic_music": "Ηλεκτρονική Μουσική",
+ "bus": "Λεωφορείο",
+ "train": "Εκπαίδευση",
+ "boat": "Βάρκα",
+ "sigh": "Αναστεναγμός",
+ "singing": "Τραγούδι",
+ "choir": "Χορωδία",
+ "whistling": "Σφύριγμα",
+ "camera": "Κάμερα",
+ "wheeze": "Ξεφύσημα",
+ "yodeling": "Λαρυγγισμός",
+ "chant": "Ύμνος",
+ "mantra": "Μάντρα",
+ "synthetic_singing": "Συνθετικό Τραγούδι"
}
diff --git a/web/public/locales/el/common.json b/web/public/locales/el/common.json
index d521af9a0..5978d6cff 100644
--- a/web/public/locales/el/common.json
+++ b/web/public/locales/el/common.json
@@ -1,8 +1,182 @@
{
"time": {
- "untilForTime": "Ως{{time}}",
+ "untilForTime": "Ως {{time}}",
"untilForRestart": "Μέχρι να γίνει επανεκίννηση του Frigate.",
"untilRestart": "Μέχρι να γίνει επανεκκίνηση",
- "justNow": "Μόλις τώρα"
+ "justNow": "Μόλις τώρα",
+ "ago": "Πριν {{timeAgo}}",
+ "today": "Σήμερα",
+ "yesterday": "Εχθές",
+ "last7": "Τελευταίες 7 ημέρες",
+ "year_one": "{{time}} χρόνος",
+ "year_other": "{{time}} χρόνια",
+ "month_one": "{{time}} μήνας",
+ "month_other": "{{time}} μήνες",
+ "day_one": "{{time}} ημέρα",
+ "day_other": "{{time}} ημέρες",
+ "hour_one": "{{time}} ώρα",
+ "hour_other": "{{time}} ώρες",
+ "minute_one": "{{time}} λεπτό",
+ "minute_other": "{{time}} λεπτά",
+ "second_one": "{{time}} δευτερόλεπτο",
+ "second_other": "{{time}} δευτερόλεπτα",
+ "last14": "Τελευταίες 14 ημέρες",
+ "last30": "Τελευταίες 30 ημέρες",
+ "thisWeek": "Αυτή την εβδομάδα",
+ "lastWeek": "Προηγούμενη Εβδομάδα",
+ "am": "π.μ.",
+ "yr": "{{time}}χρ",
+ "mo": "{{time}}μη",
+ "thisMonth": "Αυτό τον Μήνα",
+ "lastMonth": "Τελευταίος Μήνας",
+ "5minutes": "5 λεπτά",
+ "10minutes": "10 λεπτά",
+ "30minutes": "30 λεπτά",
+ "1hour": "1 ώρα",
+ "12hours": "12 ώρες",
+ "24hours": "24 ώρες",
+ "pm": "μ.μ.",
+ "formattedTimestamp": {
+ "12hour": "d MMM, h:mm:ss aaa",
+ "24hour": "d MMM, HH:mm:ss"
+ },
+ "formattedTimestamp2": {
+ "12hour": "MM/dd h:mm:ssa",
+ "24hour": "d MMM HH:mm:ss"
+ },
+ "formattedTimestampHourMinute": {
+ "12hour": "h:mm aaa",
+ "24hour": "HH:mm"
+ },
+ "formattedTimestampHourMinuteSecond": {
+ "12hour": "h:mm:ss aaa",
+ "24hour": "HH:mm:ss"
+ },
+ "formattedTimestampMonthDayHourMinute": {
+ "12hour": "d MMM, h:mm aaa",
+ "24hour": "d MMM, HH:mm"
+ },
+ "formattedTimestampMonthDayYear": {
+ "12hour": "d MMM yyyy",
+ "24hour": "d MMM yyyy"
+ },
+ "formattedTimestampMonthDayYearHourMinute": {
+ "12hour": "d MMM yyyy, h:mm aaa",
+ "24hour": "d MMM yyyy, HH:mm"
+ },
+ "formattedTimestampMonthDay": "d MMM",
+ "formattedTimestampFilename": {
+ "12hour": "dd-MM-yy-h-mm-ss-a",
+ "24hour": "dd-MM-yy-HH-mm-ss"
+ },
+ "d": "{{time}}η",
+ "h": "{{time}}ω",
+ "m": "{{time}}λ",
+ "s": "{{time}}δ",
+ "inProgress": "Σε εξέλιξη",
+ "invalidStartTime": "Μη έγκυρη ώρα έναρξης",
+ "invalidEndTime": "Μη έγκυρη ώρα λήξης",
+ "never": "Ποτέ"
+ },
+ "menu": {
+ "live": {
+ "cameras": {
+ "count_one": "{{count}} Κάμερα",
+ "count_other": "{{count}} Κάμερες"
+ }
+ }
+ },
+ "button": {
+ "save": "Αποθήκευση",
+ "apply": "Εφαρμογή",
+ "reset": "Επαναφορά",
+ "done": "Τέλος",
+ "enabled": "Ενεργοποιημένο",
+ "enable": "Ενεργοποίηση",
+ "disabled": "Απενεργοποιημένο",
+ "disable": "Απενεργοποίηση",
+ "saving": "Αποθήκευση…",
+ "cancel": "Ακύρωση",
+ "close": "Κλείσιμο",
+ "copy": "Αντιγραφή",
+ "back": "Πίσω",
+ "pictureInPicture": "Εικόνα σε εικόνα",
+ "cameraAudio": "Ήχος κάμερας",
+ "edit": "Επεξεργασία",
+ "copyCoordinates": "Αντιγραφή συντεταγμένων",
+ "delete": "Διαγραφή",
+ "yes": "Ναι",
+ "no": "Όχι",
+ "download": "Κατέβασμα",
+ "info": "Πληροφορίες",
+ "history": "Ιστορία"
+ },
+ "unit": {
+ "speed": {
+ "mph": "mph",
+ "kph": "χλμ/ώρα"
+ },
+ "length": {
+ "meters": "μέτρα"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/ώρα",
+ "mbph": "MB/ώρα",
+ "gbph": "GB/ώρα"
+ }
+ },
+ "label": {
+ "back": "Επιστροφή",
+ "hide": "Απόκρυψη {{item}}",
+ "show": "Εμφάνιση {{item}}",
+ "ID": "ID",
+ "none": "Κανένα",
+ "all": "Όλα"
+ },
+ "toast": {
+ "save": {
+ "title": "Αποθήκευση",
+ "error": {
+ "title": "Αποτυχία αποθήκευσης αλλαγών διαμόρφωσης: {{errorMessage}}",
+ "noMessage": "Αποτυχία αποθήκευσης αλλαγών διαμόρφωσης"
+ }
+ }
+ },
+ "role": {
+ "admin": "Διαχειριστής",
+ "desc": "Οι διαχειριστές έχουν πλήρη πρόσβαση σε όλες τις λειτουργίες του περιβάλλοντος χρήστη Frigate. Οι θεατές έχουν περιορισμένη πρόσβαση στην προβολή καμερών, στην αναθεώρηση στοιχείων και σε ιστορικό υλικό στο περιβάλλον χρήστη.",
+ "viewer": "Θεατής"
+ },
+ "pagination": {
+ "previous": {
+ "title": "Προηγούμενο",
+ "label": "Μετάβαση στην προηγούμενη σελίδα"
+ },
+ "next": {
+ "title": "Επόμενο",
+ "label": "Μετάβαση στην επόμενη σελίδα"
+ },
+ "more": "Περισσότερες σελίδες"
+ },
+ "accessDenied": {
+ "documentTitle": "Πρόσβαση απορρίφθηκε - Frigate",
+ "title": "Πρόσβαση απορρίφθηκε",
+ "desc": "Δεν έχετε άδεια να δείτε αυτή τη σελίδα."
+ },
+ "notFound": {
+ "documentTitle": "Δεν βρέθηκε - Frigate",
+ "title": "404",
+ "desc": "Η σελίδα δεν βρέθηκε"
+ },
+ "list": {
+ "two": "{{0}} και {{1}}",
+ "many": "{{items}} και {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "internalID": "Το εσωτερικό ID που χρησιμοποίησε η Fregate στη διαμόρφωση και τη βάση δεδομένων"
}
}
diff --git a/web/public/locales/el/components/auth.json b/web/public/locales/el/components/auth.json
index 722e8efbf..c978b3667 100644
--- a/web/public/locales/el/components/auth.json
+++ b/web/public/locales/el/components/auth.json
@@ -4,7 +4,13 @@
"password": "Κωδικός",
"login": "Σύνδεση",
"errors": {
- "usernameRequired": "Απαιτείται όνομα χρήστη"
- }
+ "usernameRequired": "Απαιτείται όνομα χρήστη",
+ "passwordRequired": "Απαιτείται κωδικός",
+ "rateLimit": "Το όριο μεταφοράς έχει ξεπεραστεί. Δοκιμάστε ξανά αργότερα.",
+ "loginFailed": "Αποτυχία σύνδεσης",
+ "unknownError": "Άγνωστο σφάλμα. Ελέγξτε το αρχείο καταγραφής.",
+ "webUnknownError": "Άγνωστο σφάλμα. Εξετάστε το αρχείο καταγραφής κονσόλας."
+ },
+ "firstTimeLogin": "Προσπαθείτε να συνδεθείτε για πρώτη φορά; Τα διαπιστευτήρια είναι τυπωμένα στα logs του Frigate."
}
}
diff --git a/web/public/locales/el/components/camera.json b/web/public/locales/el/components/camera.json
index 8d0571fbe..3de7248ee 100644
--- a/web/public/locales/el/components/camera.json
+++ b/web/public/locales/el/components/camera.json
@@ -1,6 +1,42 @@
{
"group": {
"add": "Προσθήκη ομάδας καμερών",
- "label": "Ομάδες καμερών"
+ "label": "Ομάδες καμερών",
+ "edit": "Επεξεργασία ομάδας καμερών",
+ "delete": {
+ "label": "Διαγραφή ομάδας κάμερας",
+ "confirm": {
+ "title": "Επιβεβαίωση Διαγραφής",
+ "desc": "Είστε σίγουροι για την διαγραφή της ομάδας κάμερας {{name}};"
+ }
+ },
+ "name": {
+ "label": "Όνομα",
+ "placeholder": "Εισάγετε όνομα…",
+ "errorMessage": {
+ "mustLeastCharacters": "Το όνομα ομάδας κάμερας πρέπει να περιέχει τουλάχιστον 2 χαρακτήρες.",
+ "exists": "Το όνομα ομάδας κάμερας υπάρχει ήδη.",
+ "nameMustNotPeriod": "Το όνομα ομάδας κάμερας δεν μπορεί να περιλαμβάνει κενά.",
+ "invalid": "Άκυρο όνομα ομάδας κάμερας."
+ }
+ },
+ "camera": {
+ "setting": {
+ "audioIsUnavailable": "Ο ήχος δεν είναι διαθέσιμος για αυτή την μετάδοση",
+ "audio": {
+ "tips": {
+ "title": "Η κάμερα πρέπει να εκπέμπει ήχο και να είναι ρυθμισμένο το go2rtc για αυτή την μετάδοση."
+ }
+ },
+ "stream": "Μετάδοση",
+ "placeholder": "Επιλέξτε μια μετάδοση"
+ }
+ },
+ "cameras": {
+ "label": "Κάμερες",
+ "desc": "Διαλέξτε κάμερες για αυτή την ομάδα."
+ },
+ "icon": "Εικονίδιο",
+ "success": "Η ομάδα κάμερας {{name}} έχει αποθηκευθεί."
}
}
diff --git a/web/public/locales/el/components/dialog.json b/web/public/locales/el/components/dialog.json
index 5d83ef580..40c3f0545 100644
--- a/web/public/locales/el/components/dialog.json
+++ b/web/public/locales/el/components/dialog.json
@@ -32,7 +32,24 @@
},
"export": {
"time": {
- "fromTimeline": "Επιλογή από Χρονολόγιο"
+ "fromTimeline": "Επιλογή από Χρονολόγιο",
+ "lastHour_one": "Τελευταία ώρα",
+ "lastHour_other": "Τελευταίες {{count}} Ώρες",
+ "custom": "Προσαρμοσμένο",
+ "start": {
+ "title": "Αρχή Χρόνου"
+ }
+ },
+ "select": "Επιλογή",
+ "export": "Εξαγωγή",
+ "selectOrExport": "Επιλογή ή Εξαγωγή",
+ "toast": {
+ "success": "Επιτυχής έναρξη εξαγωγής. Δείτε το αρχείο στον φάκελο /exports."
+ }
+ },
+ "search": {
+ "saveSearch": {
+ "label": "Αποθήκευση αναζήτησης"
}
}
}
diff --git a/web/public/locales/el/components/filter.json b/web/public/locales/el/components/filter.json
index ecfa4905e..da69d7f0e 100644
--- a/web/public/locales/el/components/filter.json
+++ b/web/public/locales/el/components/filter.json
@@ -1,6 +1,41 @@
{
"filter": "Φίλτρο",
"labels": {
- "label": "Ετικέτες"
- }
+ "label": "Ετικέτες",
+ "all": {
+ "title": "Όλες οι ετικέτες",
+ "short": "Ετικέτες"
+ },
+ "count_one": "{{count}} Ετικέτα",
+ "count_other": "{{count}} Ετικέτες"
+ },
+ "classes": {
+ "all": {
+ "title": "Όλες οι κλάσεις"
+ },
+ "count_one": "{{count}} Κλάση",
+ "count_other": "{{count}} Κλάσεις",
+ "label": "Κλάσεις"
+ },
+ "zones": {
+ "label": "Ζώνες",
+ "all": {
+ "title": "Όλες οι ζώνες",
+ "short": "Ζώνες"
+ }
+ },
+ "score": "Σκορ",
+ "estimatedSpeed": "Εκτιμώμενη Ταχύτητα {{unit}}",
+ "features": {
+ "label": "Χαρακτηριστικά",
+ "hasSnapshot": "Έχει ένα στιγμιότυπο"
+ },
+ "dates": {
+ "selectPreset": "Διαλέξτε μια Προεπιλογή…",
+ "all": {
+ "title": "Όλες οι Ημερομηνίες",
+ "short": "Ημερομηνίες"
+ }
+ },
+ "more": "Επιπλέον Φίλτρα"
}
diff --git a/web/public/locales/el/components/player.json b/web/public/locales/el/components/player.json
index 14f444437..de23a9783 100644
--- a/web/public/locales/el/components/player.json
+++ b/web/public/locales/el/components/player.json
@@ -37,6 +37,15 @@
"value": "{{droppedFrames}} καρέ"
}
},
- "decodedFrames": "Αποκωδικοποιημένα Καρέ:"
+ "decodedFrames": "Αποκωδικοποιημένα Καρέ:",
+ "droppedFrameRate": "Ρυθμός Απορριφθέντων Καρέ:"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "Επιτυχής αποστολή εικόνας στο Frigate+"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "Αποτυχία αποστολής εικόνας στο Frigate+"
+ }
}
}
diff --git a/web/public/locales/el/objects.json b/web/public/locales/el/objects.json
index 22d5874ca..5cc7e4fe8 100644
--- a/web/public/locales/el/objects.json
+++ b/web/public/locales/el/objects.json
@@ -4,5 +4,21 @@
"car": "Αυτοκίνητο",
"motorcycle": "Μηχανή",
"airplane": "Αεροπλάνο",
- "bird": "Πουλί"
+ "bird": "Πουλί",
+ "bus": "Λεωφορείο",
+ "train": "Εκπαίδευση",
+ "boat": "Βάρκα",
+ "traffic_light": "Φανάρι Κυκλοφορίας",
+ "fire_hydrant": "Πυροσβεστικός Κρουνός",
+ "horse": "Άλογο",
+ "street_sign": "Πινακίδα Δρόμου",
+ "stop_sign": "Πινακίδα Στοπ",
+ "bear": "Αρκούδα",
+ "zebra": "Ζέμπρα",
+ "giraffe": "Καμηλοπάρδαλη",
+ "hat": "Καπέλο",
+ "parking_meter": "Παρκόμετρο",
+ "bench": "Παγκάκι",
+ "cat": "Γάτα",
+ "dog": "Σκύλος"
}
diff --git a/web/public/locales/el/views/classificationModel.json b/web/public/locales/el/views/classificationModel.json
new file mode 100644
index 000000000..926a5fc10
--- /dev/null
+++ b/web/public/locales/el/views/classificationModel.json
@@ -0,0 +1,14 @@
+{
+ "documentTitle": "Μοντέλα Ταξινόμησης - Frigate",
+ "details": {
+ "scoreInfo": "Η βαθμολογία αντιπροσωπεύει την κατά μέσο όρο ταξινομική εμπιστοσύνη μεταξύ όλων των ανιχνεύσεων αυτού του αντικειμένου.",
+ "none": "Καμία",
+ "unknown": "Άγνωστο"
+ },
+ "button": {
+ "deleteClassificationAttempts": "Διαγραφή Εικόνων Ταξινόμησης",
+ "deleteImages": "Διαγραφή Εικόνων",
+ "trainModel": "Εκπαίδευση Μοντέλου",
+ "addClassification": "Προσθήκη Ταξινόμησης"
+ }
+}
diff --git a/web/public/locales/el/views/configEditor.json b/web/public/locales/el/views/configEditor.json
index d468103fa..79917bf96 100644
--- a/web/public/locales/el/views/configEditor.json
+++ b/web/public/locales/el/views/configEditor.json
@@ -1,5 +1,18 @@
{
"documentTitle": "Επεξεργαστής ρυθμίσεων - Frigate",
"configEditor": "Επεξεργαστής Ρυθμίσεων",
- "saveAndRestart": "Αποθήκευση και επανεκκίνηση"
+ "saveAndRestart": "Αποθήκευση και επανεκκίνηση",
+ "safeConfigEditor": "Επεξεργαστής ρυθμίσεων (Ασφαλής Λειτουργία)",
+ "safeModeDescription": "Το Frigate είναι σε ασφαλή λειτουργία λόγω λάθους εγκυρότητας ρυθμίσεων.",
+ "copyConfig": "Αντιγραφή Ρυθμίσεων",
+ "saveOnly": "Μόνο Αποθήκευση",
+ "confirm": "Έξοδος χωρίς αποθήκευση;",
+ "toast": {
+ "success": {
+ "copyToClipboard": "Οι Ρυθμίσεις αντιγράφτηκαν στο πρόχειρο."
+ },
+ "error": {
+ "savingError": "Σφάλμα αποθήκευσης ρυθμίσεων"
+ }
+ }
}
diff --git a/web/public/locales/el/views/events.json b/web/public/locales/el/views/events.json
index 76dc0264a..82031a897 100644
--- a/web/public/locales/el/views/events.json
+++ b/web/public/locales/el/views/events.json
@@ -4,5 +4,32 @@
"motion": {
"label": "Κίνηση",
"only": "Κίνηση μόνο"
- }
+ },
+ "allCameras": "Όλες οι κάμερες",
+ "empty": {
+ "alert": "Δεν υπάρχουν ειδοποιήσεις για εξέταση",
+ "detection": "Δεν υπάρχουν εντοπισμοί για εξέταση",
+ "motion": "Δεν βρέθηκαν στοιχεία κίνησης",
+ "recordingsDisabled": {
+ "title": "Οι καταγραφές πρέπει να είναι ενεργοποιημένες"
+ }
+ },
+ "timeline": "Χρονολόγιο",
+ "timeline.aria": "Επιλογή χρονοσειράς",
+ "events": {
+ "label": "Γεγονότα",
+ "aria": "Επιλογή γεγονότων",
+ "noFoundForTimePeriod": "Δεν βρέθηκαν γεγονότα για αυτή την περίοδο."
+ },
+ "selected_other": "{{count}} επελεγμένα",
+ "camera": "Κάμερα",
+ "detected": "ανιχνέυτηκε",
+ "documentTitle": "Προεσκόπιση - Frigate",
+ "recordings": {
+ "documentTitle": "Καταγραφές - Frigate"
+ },
+ "calendarFilter": {
+ "last24Hours": "Τελευταίες 24 Ώρες"
+ },
+ "markAsReviewed": "Επιβεβαίωση ως Ελεγμένα"
}
diff --git a/web/public/locales/el/views/explore.json b/web/public/locales/el/views/explore.json
index a48e770ea..a33fb17bf 100644
--- a/web/public/locales/el/views/explore.json
+++ b/web/public/locales/el/views/explore.json
@@ -1,3 +1,52 @@
{
- "documentTitle": "Εξερευνήστε - Frigate"
+ "documentTitle": "Εξερευνήστε - Frigate",
+ "generativeAI": "Παραγωγική τεχνητή νοημοσύνη",
+ "exploreMore": "Εξερευνήστε περισσότερα αντικείμενα {{label}}",
+ "exploreIsUnavailable": {
+ "title": "Η εξερεύνηση δεν είναι διαθέσιμη",
+ "embeddingsReindexing": {
+ "context": "Η εξερεύνηση μπορεί να πραγματοποιηθεί μετά το πέρας της καταλογράφησης εμπλουτισμών.",
+ "startingUp": "Εκκίνηση…",
+ "estimatedTime": "Εκτιμώμενο υπόλοιπο χρόνου:",
+ "finishingShortly": "Ολοκλήρωση συντόμως",
+ "step": {
+ "thumbnailsEmbedded": "Ενσωματωμένες εικόνες: ",
+ "descriptionsEmbedded": "Ενσωματωμένες περιγραφές: ",
+ "trackedObjectsProcessed": "Επεξεργασία παρακολουθούμενων αντικειμένων: "
+ }
+ },
+ "downloadingModels": {
+ "context": "Το Frigate κατεβάζει τα απαιτούμενα μοντέλα ενσωμάτωσης για να υποστηρίξει την σημασιολογική αναζήτηση. Αυτό μπορεί να διαρκέσει αρκετά λεπτά αναλόγως και της ταχύτητας σύνδεσης με το διαδύκτιο.",
+ "setup": {
+ "visionModel": "Οπτικό Μοντέλο",
+ "visionModelFeatureExtractor": "Εξαγωγή χαρακτηριστικών οπτικού μοντέλου",
+ "textModel": "Μοντέλο γραφής"
+ }
+ }
+ },
+ "details": {
+ "timestamp": "Χρονοσήμανση",
+ "item": {
+ "tips": {
+ "mismatch_one": "{{count}} μη διαθέσιμο αντικείμενο ανιχνεύτηκε και έχει συνιπολογιστεί στην προεσκόπιση. Αυτό το αντικείμενο είτε δεν πληροί τις προϋποθέσεις ως προειδοποίηση ή ανίχνευση ή έχει ήδη καθαριστεί/διαγραφεί.",
+ "mismatch_other": "{{count}} μη διαθέσιμα αντικείμενα ανιχνεύτηκαν και έχουν συνιπολογιστεί στην προεσκόπιση. Αυτά τα αντικείμενα είτε δεν πληρούν τις προϋποθέσεις ως προειδοποιήσεις ή ανιχνεύσεις ή έχουν ήδη καθαριστεί/διαγραφεί."
+ }
+ }
+ },
+ "type": {
+ "video": "βίντεο",
+ "object_lifecycle": "κύκλος ζωής αντικειμένου"
+ },
+ "objectLifecycle": {
+ "title": "Κύκλος Ζωής Αντικειμένου",
+ "noImageFound": "Δεν βρέθηκε εικόνα για αυτό το χρονικό σημείο."
+ },
+ "trackedObjectsCount_one": "{{count}} παρακολουθούμενο αντικείμενο ",
+ "trackedObjectsCount_other": "{{count}} παρακολουθούμενα αντικείμενα ",
+ "itemMenu": {
+ "downloadVideo": {
+ "label": "Λήψη βίντεο",
+ "aria": "Λήψη βίντεο"
+ }
+ }
}
diff --git a/web/public/locales/el/views/exports.json b/web/public/locales/el/views/exports.json
index e8517ae5c..f6526eea0 100644
--- a/web/public/locales/el/views/exports.json
+++ b/web/public/locales/el/views/exports.json
@@ -1,5 +1,22 @@
{
"documentTitle": "Εξαγωγή - Frigate",
"search": "Αναζήτηση",
- "deleteExport": "Διαγραφή εξαγωγής"
+ "deleteExport": "Διαγραφή εξαγωγής",
+ "noExports": "Δεν βρέθηκαν εξαγωγές",
+ "deleteExport.desc": "Είστε σίγουροι οτι θέλετε να διαγράψετε {{exportName}};",
+ "editExport": {
+ "title": "Μετονομασία Εξαγωγής",
+ "desc": "Εισάγετε ένα νέο όνομα για την εξαγωγή.",
+ "saveExport": "Αποθήκευση Εξαγωγής"
+ },
+ "toast": {
+ "error": {
+ "renameExportFailed": "Αποτυχία μετονομασίας εξαγωγής:{{errorMessage}}"
+ }
+ },
+ "tooltip": {
+ "shareExport": "Κοινή χρήση εξαγωγής",
+ "downloadVideo": "Λήψη βίντεο",
+ "deleteExport": "Διαγραφή εξαγωγής"
+ }
}
diff --git a/web/public/locales/el/views/faceLibrary.json b/web/public/locales/el/views/faceLibrary.json
index 8ee6c9690..7bb548e07 100644
--- a/web/public/locales/el/views/faceLibrary.json
+++ b/web/public/locales/el/views/faceLibrary.json
@@ -1,10 +1,50 @@
{
"description": {
- "addFace": "Οδηγός για την προσθήκη μιας νέας συλλογής στη Βιβλιοθήκη Προσώπων.",
+ "addFace": "Προσθέστε μια νέα συλλογή στη Βιβλιοθήκη Προσώπων ανεβάζοντας την πρώτη σας εικόνα.",
"placeholder": "Εισαγάγετε ένα όνομα για αυτήν τη συλλογή",
"invalidName": "Μη έγκυρο όνομα. Τα ονόματα μπορούν να περιλαμβάνουν γράμματα, αριθμούς, κενό διάστημα, απόστροφο, παύλα, κάτω παύλα."
},
"details": {
- "person": "Άτομο"
+ "person": "Άτομο",
+ "subLabelScore": "Σκορ υποετικέτας",
+ "scoreInfo": "Το σκορ υποετικέτας είναι το σταθμισμένο σκορ όλων των αναγνωρισμένων προσώπων, αυτό μπορεί να διαφέρει από το σκορ που φαίνεται στο στιγμιότυπο.",
+ "face": "Λεπτομέρειες προσώπου",
+ "faceDesc": "Λεπτομέρειες του παρακολουθούμενου αντικειμένου που παρήγε αυτό το πρόσωπο",
+ "timestamp": "Χρονοσήμανση",
+ "unknown": "Άγνωστο"
+ },
+ "deleteFaceAttempts": {
+ "desc_one": "Είστε σίγουροι ότι θέλετε να διαγράψετε {{count}} πρόσωπο; Αυτή η πράξη δεν επαναφέρεται.",
+ "desc_other": "Είστε σίγουροι ότι θέλετε να διαγράψετε {{count}} πρόσωπα; Αυτή η πράξη δεν επαναφέρεται."
+ },
+ "toast": {
+ "success": {
+ "deletedFace_one": "Επιτυχής διαγραφή {{count}} προσώπου.",
+ "deletedFace_other": "Επιτυχής διαγραφή {{count}} προσώπων.",
+ "deletedName_one": "{{count}} πρόσωπο διεγράφη επιτυχημένα.",
+ "deletedName_other": "{{count}} πρόσωπα διεγράφη επιτυχημένα."
+ }
+ },
+ "documentTitle": "Βιβλιοθήκη προσώπων - Frigate",
+ "uploadFaceImage": {
+ "title": "Μεταφόρτωση Εικόνας Προσώπου",
+ "desc": "Ανεβάστε μια εικόνα για να σαρώσετε πρόσωπα και να τα συμπεριλάβετε στο {{pageToggle}}"
+ },
+ "steps": {
+ "nextSteps": "Επόμενα βήματα",
+ "description": {
+ "uploadFace": "Μεταφορτώστε μια εικόνα του/της {{name}} που δείχνει το πρόσωπο τους από μπροστινή λήψη. Η εικόνα δεν χρειάζεται να περιέχει μόνο το πρόσωπο τους."
+ }
+ },
+ "train": {
+ "title": "Εκπαίδευση",
+ "aria": "Επιλογή εκπαίδευσης",
+ "empty": "Δεν υπάρχουν πρόσφατες προσπάθειες αναγνώρισης προσώπου"
+ },
+ "collections": "Συλλογές",
+ "createFaceLibrary": {
+ "title": "Δημιουργία Συλλογής",
+ "desc": "Δημιουργία νέας συλλογής",
+ "new": "Δημιουργία Νέου Προσώπου"
}
}
diff --git a/web/public/locales/el/views/live.json b/web/public/locales/el/views/live.json
index daeb09636..b2427114e 100644
--- a/web/public/locales/el/views/live.json
+++ b/web/public/locales/el/views/live.json
@@ -1,6 +1,69 @@
{
"documentTitle": "Ζωντανά - Frigate",
"twoWayTalk": {
- "enable": "Ενεργοποίηση αμφίδρομης επικοινωνίας"
+ "enable": "Ενεργοποίηση αμφίδρομης επικοινωνίας",
+ "disable": "Απενεργοποίηση αμφίδρομης επικοινωνίας"
+ },
+ "documentTitle.withCamera": "{{camera}} - Ζωντανή μετάδοση - Frigate",
+ "lowBandwidthMode": "Λειτουργία χαμηλής ευρυζωνικότητας",
+ "cameraAudio": {
+ "enable": "Ενεργοποίηση ήχου Κάμερας",
+ "disable": "Απενεργοποίηση Ήχου Κάμερας"
+ },
+ "ptz": {
+ "move": {
+ "clickMove": {
+ "label": "Πατήστε στο πλαίσιο για να κεντράρετε την κάμερα",
+ "enable": "Ενεργοποίηση κλικ για μεταφορά",
+ "disable": "Απενεργοποίηση κλικ για μεταφορά"
+ },
+ "left": {
+ "label": "Κίνηση κάμερας προς τα αριστερά"
+ },
+ "up": {
+ "label": "Κίνηση κάμερας προς τα πάνω"
+ },
+ "down": {
+ "label": "Κίνηση κάμερας προς τα κάτω"
+ },
+ "right": {
+ "label": "Κίνηση κάμερας προς τα δεξιά"
+ }
+ },
+ "zoom": {
+ "in": {
+ "label": "Ζουμάρισμα κάμερας προς τα μέσα"
+ },
+ "out": {
+ "label": "Ζουμάρισμα κάμερας προς τα έξω"
+ }
+ }
+ },
+ "camera": {
+ "enable": "Ενεργοποίηση Κάμερας",
+ "disable": "Απενεργοποίηση Κάμερας"
+ },
+ "muteCameras": {
+ "enable": "Σίγαση Όλων των Καμερών",
+ "disable": "Απενεργοποίηση Σίγασης Όλων των Καμερών"
+ },
+ "detect": {
+ "enable": "Ενεργοποίηση Ανίχνευσης",
+ "disable": "Απενεργοποίηση Ανίχνευσης"
+ },
+ "recording": {
+ "enable": "Ενεργοποίηση Καταγραφής",
+ "disable": "Απενεργοποίηση Καταγραφής"
+ },
+ "snapshots": {
+ "enable": "Ενεργοποίηση Στιγμιοτίπων",
+ "disable": "Απενεργοποίηση Στιγμιοτίπων"
+ },
+ "audioDetect": {
+ "enable": "Ενεργοποίηση Ανίχνευσης Ήχου",
+ "disable": "Απενεργοποίηση Ανίχνευσης Ήχου"
+ },
+ "noCameras": {
+ "buttonText": "Προσθήκη Κάμερας"
}
}
diff --git a/web/public/locales/el/views/recording.json b/web/public/locales/el/views/recording.json
index 063abbd2b..9681d0e2a 100644
--- a/web/public/locales/el/views/recording.json
+++ b/web/public/locales/el/views/recording.json
@@ -2,5 +2,11 @@
"filter": "Φίλτρο",
"export": "Εξαγωγή",
"calendar": "Ημερολόγιο",
- "filters": "Φίλτρα"
+ "filters": "Φίλτρα",
+ "toast": {
+ "error": {
+ "noValidTimeSelected": "Μη επιλογή έγκυρης περιόδου",
+ "endTimeMustAfterStartTime": "Το επιλεγμένο τέλος περιόδου πρέπει να είναι μετά την επιλεγμένη αρχή περιόδου"
+ }
+ }
}
diff --git a/web/public/locales/el/views/search.json b/web/public/locales/el/views/search.json
index 96ca56e0d..1281446cf 100644
--- a/web/public/locales/el/views/search.json
+++ b/web/public/locales/el/views/search.json
@@ -2,6 +2,28 @@
"search": "Αναζήτηση",
"savedSearches": "Αποθηκευμένες Αναζητήσεις",
"button": {
- "clear": "Εκαθάρηση αναζήτησης"
+ "clear": "Εκαθάρηση αναζήτησης",
+ "save": "Αποθήκευση αναζήτησης",
+ "delete": "Διαγραφή αποθηκευμένης αναζήτησης",
+ "filterInformation": "Πληροφορίες φίλτρου",
+ "filterActive": "Φίλτρα ενεργά"
+ },
+ "searchFor": "Αναζήτηση {{inputValue}}",
+ "trackedObjectId": "Σήμανση παρακολουθούμενου αντικειμένου",
+ "filter": {
+ "label": {
+ "cameras": "Κάμερες",
+ "labels": "Ετικέτες",
+ "zones": "Ζώνες",
+ "max_speed": "Ανώτατη Ταχύτητα",
+ "recognized_license_plate": "Αναγνωρισμένη Πινακίδα Κυκλοφορίας",
+ "has_clip": "Έχει Κλιπ",
+ "has_snapshot": "Έχει Στιγμιότυπο",
+ "sub_labels": "Υποετικέτες",
+ "search_type": "Τύπος Αναζήτησης",
+ "time_range": "Χρονική Περίοδος",
+ "before": "Πριν",
+ "after": "Μετά"
+ }
}
}
diff --git a/web/public/locales/el/views/settings.json b/web/public/locales/el/views/settings.json
index 0d184f3d2..75884e0d2 100644
--- a/web/public/locales/el/views/settings.json
+++ b/web/public/locales/el/views/settings.json
@@ -2,6 +2,57 @@
"documentTitle": {
"default": "Ρυθμίσεις - Frigate",
"authentication": "Ρυθμίσεις ελέγχου ταυτοποίησης - Frigate",
- "camera": "Ρυθμίσεις Κάμερας - Frigate"
+ "camera": "Ρυθμίσεις Κάμερας - Frigate",
+ "enrichments": "Ρυθμίσεις εμπλουτισμού - Frigate",
+ "masksAndZones": "Ρυθμίσεις Μασκών και Ζωνών - Frigate",
+ "motionTuner": "Ρύθμιση Κίνησης - Frigate",
+ "object": "Επίλυση σφαλμάτων - Frigate",
+ "general": "Ρυθμίσεις UI - Frigate",
+ "frigatePlus": "Ρυθμίσεις Frigate+ - Frigate",
+ "notifications": "Ρυθμίσεις Ειδοποιήσεων",
+ "cameraManagement": "Διαχείριση καμερών - Frigate",
+ "cameraReview": "Ρυθμίσεις αξιολόγησης κάμερας - Frigate"
+ },
+ "masksAndZones": {
+ "zones": {
+ "point_one": "{{count}} σημέιο",
+ "point_other": "{{count}} σημεία"
+ },
+ "motionMasks": {
+ "point_one": "{{count}} σημείο",
+ "point_other": "{{count}} σημεία"
+ },
+ "objectMasks": {
+ "point_one": "{{count}} σημέιο",
+ "point_other": "{{count}} σημεία"
+ }
+ },
+ "menu": {
+ "ui": "Επιφάνεια Εργασίας",
+ "enrichments": "Εμπλουτισμοί",
+ "cameras": "Ρυθμίσεις Κάμερας",
+ "masksAndZones": "Μάσκες / Ζώνες",
+ "motionTuner": "Ρυθμιστής Κίνησης",
+ "debug": "Επίλυση Σφαλμάτων"
+ },
+ "dialog": {
+ "unsavedChanges": {
+ "title": "Έχετε μη αποθηκευμένες αλλαγές.",
+ "desc": "Θέλετε να αποθηκεύσετε τις αλλαγές σας πριν την συνέχεια;"
+ }
+ },
+ "cameraSetting": {
+ "camera": "Κάμερα",
+ "noCamera": "Δεν υπάρχει Κάμερα"
+ },
+ "triggers": {
+ "dialog": {
+ "form": {
+ "friendly_name": {
+ "placeholder": "Ονομάτισε ή περιέγραψε αυτό το εύνασμα",
+ "description": "Ένα προαιρετικό φιλικό όνομα, ή ένα περιγραφικό κείμενο για αυτό το εύνασμα."
+ }
+ }
+ }
}
}
diff --git a/web/public/locales/el/views/system.json b/web/public/locales/el/views/system.json
index 3076645d6..0ec8ff587 100644
--- a/web/public/locales/el/views/system.json
+++ b/web/public/locales/el/views/system.json
@@ -1,5 +1,39 @@
{
"documentTitle": {
- "cameras": "Στατιστικά Καμερών - Frigate"
+ "cameras": "Στατιστικά Καμερών - Frigate",
+ "storage": "Στατιστικά αποθήκευσης - Frigate",
+ "general": "Γενικά στατιστικά - Frigate",
+ "enrichments": "Στατιστικά Εμπλουτισμού - Frigate",
+ "logs": {
+ "frigate": "Frigate αρχέιο καταγραφών - Frigate",
+ "go2rtc": "Αρχείο καταγραφής Go2RTC - Frigate",
+ "nginx": "Αρχείο καταγραφών Nginx - Frigate"
+ }
+ },
+ "title": "Σύστημα",
+ "metrics": "Μετρήσεις συστήματος",
+ "logs": {
+ "download": {
+ "label": "Λήψη Αρχείων Καταγραφής"
+ },
+ "copy": {
+ "label": "Αντιγραφή στο πρόχειρο",
+ "success": "Αρχεία καταγραφής αντιγράφτηκαν στο πρόχειρο",
+ "error": "Αποτυχία αντιγραφής των αρχείων καταγραφής στο πρόχειρο"
+ },
+ "type": {
+ "label": "Τύπος",
+ "timestamp": "Χρονοσήμανση",
+ "tag": "Λέξη Κλειδί",
+ "message": "Μήνυμα"
+ }
+ },
+ "general": {
+ "title": "Γενικά",
+ "detector": {
+ "title": "Ανιχνευτές",
+ "inferenceSpeed": "Ταχύτητα Συμπεράσματος Ανιχνευτή",
+ "temperature": "Θερμοκρασία Ανιχνευτή"
+ }
}
}
diff --git a/web/public/locales/en/audio.json b/web/public/locales/en/audio.json
index de5f5638c..5c197e85b 100644
--- a/web/public/locales/en/audio.json
+++ b/web/public/locales/en/audio.json
@@ -425,5 +425,79 @@
"television": "Television",
"radio": "Radio",
"field_recording": "Field Recording",
- "scream": "Scream"
+ "scream": "Scream",
+ "sodeling": "Sodeling",
+ "chird": "Chird",
+ "change_ringing": "Change Ringing",
+ "shofar": "Shofar",
+ "liquid": "Liquid",
+ "splash": "Splash",
+ "slosh": "Slosh",
+ "squish": "Squish",
+ "drip": "Drip",
+ "pour": "Pour",
+ "trickle": "Trickle",
+ "gush": "Gush",
+ "fill": "Fill",
+ "spray": "Spray",
+ "pump": "Pump",
+ "stir": "Stir",
+ "boiling": "Boiling",
+ "sonar": "Sonar",
+ "arrow": "Arrow",
+ "whoosh": "Whoosh",
+ "thump": "Thump",
+ "thunk": "Thunk",
+ "electronic_tuner": "Electronic Tuner",
+ "effects_unit": "Effects Unit",
+ "chorus_effect": "Chorus Effect",
+ "basketball_bounce": "Basketball Bounce",
+ "bang": "Bang",
+ "slap": "Slap",
+ "whack": "Whack",
+ "smash": "Smash",
+ "breaking": "Breaking",
+ "bouncing": "Bouncing",
+ "whip": "Whip",
+ "flap": "Flap",
+ "scratch": "Scratch",
+ "scrape": "Scrape",
+ "rub": "Rub",
+ "roll": "Roll",
+ "crushing": "Crushing",
+ "crumpling": "Crumpling",
+ "tearing": "Tearing",
+ "beep": "Beep",
+ "ping": "Ping",
+ "ding": "Ding",
+ "clang": "Clang",
+ "squeal": "Squeal",
+ "creak": "Creak",
+ "rustle": "Rustle",
+ "whir": "Whir",
+ "clatter": "Clatter",
+ "sizzle": "Sizzle",
+ "clicking": "Clicking",
+ "clickety_clack": "Clickety Clack",
+ "rumble": "Rumble",
+ "plop": "Plop",
+ "hum": "Hum",
+ "zing": "Zing",
+ "boing": "Boing",
+ "crunch": "Crunch",
+ "sine_wave": "Sine Wave",
+ "harmonic": "Harmonic",
+ "chirp_tone": "Chirp Tone",
+ "pulse": "Pulse",
+ "inside": "Inside",
+ "outside": "Outside",
+ "reverberation": "Reverberation",
+ "echo": "Echo",
+ "noise": "Noise",
+ "mains_hum": "Mains Hum",
+ "distortion": "Distortion",
+ "sidetone": "Sidetone",
+ "cacophony": "Cacophony",
+ "throbbing": "Throbbing",
+ "vibration": "Vibration"
}
diff --git a/web/public/locales/en/common.json b/web/public/locales/en/common.json
index 86304fff3..300f74ddb 100644
--- a/web/public/locales/en/common.json
+++ b/web/public/locales/en/common.json
@@ -3,6 +3,7 @@
"untilForTime": "Until {{time}}",
"untilForRestart": "Until Frigate restarts.",
"untilRestart": "Until restart",
+ "never": "Never",
"ago": "{{timeAgo}} ago",
"justNow": "Just now",
"today": "Today",
@@ -72,7 +73,10 @@
"formattedTimestampFilename": {
"12hour": "MM-dd-yy-h-mm-ss-a",
"24hour": "MM-dd-yy-HH-mm-ss"
- }
+ },
+ "inProgress": "In progress",
+ "invalidStartTime": "Invalid start time",
+ "invalidEndTime": "Invalid end time"
},
"unit": {
"speed": {
@@ -82,10 +86,33 @@
"length": {
"feet": "feet",
"meters": "meters"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/hour",
+ "mbph": "MB/hour",
+ "gbph": "GB/hour"
}
},
"label": {
- "back": "Go back"
+ "back": "Go back",
+ "hide": "Hide {{item}}",
+ "show": "Show {{item}}",
+ "ID": "ID",
+ "none": "None",
+ "all": "All",
+ "other": "Other"
+ },
+ "list": {
+ "two": "{{0}} and {{1}}",
+ "many": "{{items}}, and {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Optional",
+ "internalID": "The Internal ID Frigate uses in the configuration and database"
},
"button": {
"apply": "Apply",
@@ -122,7 +149,8 @@
"unselect": "Unselect",
"export": "Export",
"deleteNow": "Delete Now",
- "next": "Next"
+ "next": "Next",
+ "continue": "Continue"
},
"menu": {
"system": "System",
@@ -165,6 +193,7 @@
"yue": "粵語 (Cantonese)",
"th": "ไทย (Thai)",
"ca": "Català (Catalan)",
+ "hr": "Hrvatski (Croatian)",
"sr": "Српски (Serbian)",
"sl": "Slovenščina (Slovenian)",
"lt": "Lietuvių (Lithuanian)",
@@ -215,6 +244,7 @@
"export": "Export",
"uiPlayground": "UI Playground",
"faceLibrary": "Face Library",
+ "classification": "Classification",
"user": {
"title": "User",
"account": "Account",
@@ -262,5 +292,9 @@
"title": "404",
"desc": "Page not found"
},
- "selectItem": "Select {{item}}"
+ "selectItem": "Select {{item}}",
+ "readTheDocumentation": "Read the documentation",
+ "information": {
+ "pixels": "{{area}}px"
+ }
}
diff --git a/web/public/locales/en/components/auth.json b/web/public/locales/en/components/auth.json
index 05c2a779f..56b750070 100644
--- a/web/public/locales/en/components/auth.json
+++ b/web/public/locales/en/components/auth.json
@@ -3,6 +3,7 @@
"user": "Username",
"password": "Password",
"login": "Login",
+ "firstTimeLogin": "Trying to log in for the first time? Credentials are printed in the Frigate logs.",
"errors": {
"usernameRequired": "Username is required",
"passwordRequired": "Password is required",
diff --git a/web/public/locales/en/components/camera.json b/web/public/locales/en/components/camera.json
index 10513a729..864efa6c4 100644
--- a/web/public/locales/en/components/camera.json
+++ b/web/public/locales/en/components/camera.json
@@ -27,6 +27,7 @@
"icon": "Icon",
"success": "Camera group ({{name}}) has been saved.",
"camera": {
+ "birdseye": "Birdseye",
"setting": {
"label": "Camera Streaming Settings",
"title": "{{cameraName}} Streaming Settings",
@@ -35,8 +36,7 @@
"audioIsUnavailable": "Audio is unavailable for this stream",
"audio": {
"tips": {
- "title": "Audio must be output from your camera and configured in go2rtc for this stream.",
- "document": "Read the documentation "
+ "title": "Audio must be output from your camera and configured in go2rtc for this stream."
}
},
"stream": "Stream",
diff --git a/web/public/locales/en/components/dialog.json b/web/public/locales/en/components/dialog.json
index 8b2dc0b88..91ff38d82 100644
--- a/web/public/locales/en/components/dialog.json
+++ b/web/public/locales/en/components/dialog.json
@@ -1,6 +1,7 @@
{
"restart": {
"title": "Are you sure you want to restart Frigate?",
+ "description": "This will briefly stop Frigate while it restarts.",
"button": "Restart",
"restarting": {
"title": "Frigate is Restarting",
@@ -52,7 +53,8 @@
"export": "Export",
"selectOrExport": "Select or Export",
"toast": {
- "success": "Successfully started export. View the file in the /exports folder.",
+ "success": "Successfully started export. View the file in the exports page.",
+ "view": "View",
"error": {
"failed": "Failed to start export: {{error}}",
"endTimeMustAfterStartTime": "End time must be after start time",
@@ -69,8 +71,7 @@
"restreaming": {
"disabled": "Restreaming is not enabled for this camera.",
"desc": {
- "title": "Set up go2rtc for additional live view options and audio for this camera.",
- "readTheDocumentation": "Read the documentation"
+ "title": "Set up go2rtc for additional live view options and audio for this camera."
}
},
"showStats": {
@@ -107,7 +108,16 @@
"button": {
"export": "Export",
"markAsReviewed": "Mark as reviewed",
+ "markAsUnreviewed": "Mark as unreviewed",
"deleteNow": "Delete Now"
}
+ },
+ "imagePicker": {
+ "selectImage": "Select a tracked object's thumbnail",
+ "unknownLabel": "Saved Trigger Image",
+ "search": {
+ "placeholder": "Search by label or sub label..."
+ },
+ "noImages": "No thumbnails found for this camera"
}
}
diff --git a/web/public/locales/en/components/filter.json b/web/public/locales/en/components/filter.json
index 08a0ee2b2..e9ae5c769 100644
--- a/web/public/locales/en/components/filter.json
+++ b/web/public/locales/en/components/filter.json
@@ -1,5 +1,11 @@
{
"filter": "Filter",
+ "classes": {
+ "label": "Classes",
+ "all": { "title": "All Classes" },
+ "count_one": "{{count}} Class",
+ "count_other": "{{count}} Classes"
+ },
"labels": {
"label": "Labels",
"all": {
@@ -32,6 +38,10 @@
"label": "Sub Labels",
"all": "All Sub Labels"
},
+ "attributes": {
+ "label": "Classification Attributes",
+ "all": "All Attributes"
+ },
"score": "Score",
"estimatedSpeed": "Estimated Speed ({{unit}})",
"features": {
@@ -121,6 +131,8 @@
"loading": "Loading recognized license plates…",
"placeholder": "Type to search license plates…",
"noLicensePlatesFound": "No license plates found.",
- "selectPlatesFromList": "Select one or more plates from the list."
+ "selectPlatesFromList": "Select one or more plates from the list.",
+ "selectAll": "Select all",
+ "clearAll": "Clear all"
}
}
diff --git a/web/public/locales/en/config/audio.json b/web/public/locales/en/config/audio.json
new file mode 100644
index 000000000..f9aaffa6b
--- /dev/null
+++ b/web/public/locales/en/config/audio.json
@@ -0,0 +1,26 @@
+{
+ "label": "Global Audio events configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable audio events."
+ },
+ "max_not_heard": {
+ "label": "Seconds of not hearing the type of audio to end the event."
+ },
+ "min_volume": {
+ "label": "Min volume required to run audio detection."
+ },
+ "listen": {
+ "label": "Audio to listen for."
+ },
+ "filters": {
+ "label": "Audio filters."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of audio detection."
+ },
+ "num_threads": {
+ "label": "Number of detection threads"
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/audio_transcription.json b/web/public/locales/en/config/audio_transcription.json
new file mode 100644
index 000000000..6922b9d80
--- /dev/null
+++ b/web/public/locales/en/config/audio_transcription.json
@@ -0,0 +1,23 @@
+{
+ "label": "Audio transcription config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable audio transcription."
+ },
+ "language": {
+ "label": "Language abbreviation to use for audio event transcription/translation."
+ },
+ "device": {
+ "label": "The device used for license plate recognition."
+ },
+ "model_size": {
+ "label": "The size of the embeddings model used."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of camera."
+ },
+ "live_enabled": {
+ "label": "Enable live transcriptions."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/auth.json b/web/public/locales/en/config/auth.json
new file mode 100644
index 000000000..a524d8d1b
--- /dev/null
+++ b/web/public/locales/en/config/auth.json
@@ -0,0 +1,35 @@
+{
+ "label": "Auth configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable authentication"
+ },
+ "reset_admin_password": {
+ "label": "Reset the admin password on startup"
+ },
+ "cookie_name": {
+ "label": "Name for jwt token cookie"
+ },
+ "cookie_secure": {
+ "label": "Set secure flag on cookie"
+ },
+ "session_length": {
+ "label": "Session length for jwt session tokens"
+ },
+ "refresh_time": {
+ "label": "Refresh the session if it is going to expire in this many seconds"
+ },
+ "failed_login_rate_limit": {
+ "label": "Rate limits for failed login attempts."
+ },
+ "trusted_proxies": {
+ "label": "Trusted proxies for determining IP address to rate limit"
+ },
+ "hash_iterations": {
+ "label": "Password hash iterations"
+ },
+ "roles": {
+ "label": "Role to camera mappings. Empty list grants access to all cameras."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/birdseye.json b/web/public/locales/en/config/birdseye.json
new file mode 100644
index 000000000..f122f314c
--- /dev/null
+++ b/web/public/locales/en/config/birdseye.json
@@ -0,0 +1,37 @@
+{
+ "label": "Birdseye configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable birdseye view."
+ },
+ "mode": {
+ "label": "Tracking mode."
+ },
+ "restream": {
+ "label": "Restream birdseye via RTSP."
+ },
+ "width": {
+ "label": "Birdseye width."
+ },
+ "height": {
+ "label": "Birdseye height."
+ },
+ "quality": {
+ "label": "Encoding quality."
+ },
+ "inactivity_threshold": {
+ "label": "Birdseye Inactivity Threshold"
+ },
+ "layout": {
+ "label": "Birdseye Layout Config",
+ "properties": {
+ "scaling_factor": {
+ "label": "Birdseye Scaling Factor"
+ },
+ "max_cameras": {
+ "label": "Max cameras"
+ }
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/camera_groups.json b/web/public/locales/en/config/camera_groups.json
new file mode 100644
index 000000000..2900e9c67
--- /dev/null
+++ b/web/public/locales/en/config/camera_groups.json
@@ -0,0 +1,14 @@
+{
+ "label": "Camera group configuration",
+ "properties": {
+ "cameras": {
+ "label": "List of cameras in this group."
+ },
+ "icon": {
+ "label": "Icon that represents camera group."
+ },
+ "order": {
+ "label": "Sort order for group."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/cameras.json b/web/public/locales/en/config/cameras.json
new file mode 100644
index 000000000..67015bde5
--- /dev/null
+++ b/web/public/locales/en/config/cameras.json
@@ -0,0 +1,761 @@
+{
+ "label": "Camera configuration.",
+ "properties": {
+ "name": {
+ "label": "Camera name."
+ },
+ "friendly_name": {
+ "label": "Camera friendly name used in the Frigate UI."
+ },
+ "enabled": {
+ "label": "Enable camera."
+ },
+ "audio": {
+ "label": "Audio events configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable audio events."
+ },
+ "max_not_heard": {
+ "label": "Seconds of not hearing the type of audio to end the event."
+ },
+ "min_volume": {
+ "label": "Min volume required to run audio detection."
+ },
+ "listen": {
+ "label": "Audio to listen for."
+ },
+ "filters": {
+ "label": "Audio filters."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of audio detection."
+ },
+ "num_threads": {
+ "label": "Number of detection threads"
+ }
+ }
+ },
+ "audio_transcription": {
+ "label": "Audio transcription config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable audio transcription."
+ },
+ "language": {
+ "label": "Language abbreviation to use for audio event transcription/translation."
+ },
+ "device": {
+ "label": "The device used for license plate recognition."
+ },
+ "model_size": {
+ "label": "The size of the embeddings model used."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of camera."
+ },
+ "live_enabled": {
+ "label": "Enable live transcriptions."
+ }
+ }
+ },
+ "birdseye": {
+ "label": "Birdseye camera configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable birdseye view for camera."
+ },
+ "mode": {
+ "label": "Tracking mode for camera."
+ },
+ "order": {
+ "label": "Position of the camera in the birdseye view."
+ }
+ }
+ },
+ "detect": {
+ "label": "Object detection configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Detection Enabled."
+ },
+ "height": {
+ "label": "Height of the stream for the detect role."
+ },
+ "width": {
+ "label": "Width of the stream for the detect role."
+ },
+ "fps": {
+ "label": "Number of frames per second to process through detection."
+ },
+ "min_initialized": {
+ "label": "Minimum number of consecutive hits for an object to be initialized by the tracker."
+ },
+ "max_disappeared": {
+ "label": "Maximum number of frames the object can disappear before detection ends."
+ },
+ "stationary": {
+ "label": "Stationary objects config.",
+ "properties": {
+ "interval": {
+ "label": "Frame interval for checking stationary objects."
+ },
+ "threshold": {
+ "label": "Number of frames without a position change for an object to be considered stationary"
+ },
+ "max_frames": {
+ "label": "Max frames for stationary objects.",
+ "properties": {
+ "default": {
+ "label": "Default max frames."
+ },
+ "objects": {
+ "label": "Object specific max frames."
+ }
+ }
+ },
+ "classifier": {
+ "label": "Enable visual classifier for determing if objects with jittery bounding boxes are stationary."
+ }
+ }
+ },
+ "annotation_offset": {
+ "label": "Milliseconds to offset detect annotations by."
+ }
+ }
+ },
+ "face_recognition": {
+ "label": "Face recognition config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable face recognition."
+ },
+ "min_area": {
+ "label": "Min area of face box to consider running face recognition."
+ }
+ }
+ },
+ "ffmpeg": {
+ "label": "FFmpeg configuration for the camera.",
+ "properties": {
+ "path": {
+ "label": "FFmpeg path"
+ },
+ "global_args": {
+ "label": "Global FFmpeg arguments."
+ },
+ "hwaccel_args": {
+ "label": "FFmpeg hardware acceleration arguments."
+ },
+ "input_args": {
+ "label": "FFmpeg input arguments."
+ },
+ "output_args": {
+ "label": "FFmpeg output arguments per role.",
+ "properties": {
+ "detect": {
+ "label": "Detect role FFmpeg output arguments."
+ },
+ "record": {
+ "label": "Record role FFmpeg output arguments."
+ }
+ }
+ },
+ "retry_interval": {
+ "label": "Time in seconds to wait before FFmpeg retries connecting to the camera."
+ },
+ "apple_compatibility": {
+ "label": "Set tag on HEVC (H.265) recording stream to improve compatibility with Apple players."
+ },
+ "inputs": {
+ "label": "Camera inputs."
+ }
+ }
+ },
+ "live": {
+ "label": "Live playback settings.",
+ "properties": {
+ "streams": {
+ "label": "Friendly names and restream names to use for live view."
+ },
+ "height": {
+ "label": "Live camera view height"
+ },
+ "quality": {
+ "label": "Live camera view quality"
+ }
+ }
+ },
+ "lpr": {
+ "label": "LPR config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable license plate recognition."
+ },
+ "expire_time": {
+ "label": "Expire plates not seen after number of seconds (for dedicated LPR cameras only)."
+ },
+ "min_area": {
+ "label": "Minimum area of license plate to begin running recognition."
+ },
+ "enhancement": {
+ "label": "Amount of contrast adjustment and denoising to apply to license plate images before recognition."
+ }
+ }
+ },
+ "motion": {
+ "label": "Motion detection configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable motion on all cameras."
+ },
+ "threshold": {
+ "label": "Motion detection threshold (1-255)."
+ },
+ "lightning_threshold": {
+ "label": "Lightning detection threshold (0.3-1.0)."
+ },
+ "improve_contrast": {
+ "label": "Improve Contrast"
+ },
+ "contour_area": {
+ "label": "Contour Area"
+ },
+ "delta_alpha": {
+ "label": "Delta Alpha"
+ },
+ "frame_alpha": {
+ "label": "Frame Alpha"
+ },
+ "frame_height": {
+ "label": "Frame Height"
+ },
+ "mask": {
+ "label": "Coordinates polygon for the motion mask."
+ },
+ "mqtt_off_delay": {
+ "label": "Delay for updating MQTT with no motion detected."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of motion detection."
+ }
+ }
+ },
+ "objects": {
+ "label": "Object configuration.",
+ "properties": {
+ "track": {
+ "label": "Objects to track."
+ },
+ "filters": {
+ "label": "Object filters.",
+ "properties": {
+ "min_area": {
+ "label": "Minimum area of bounding box for object to be counted. Can be pixels (int) or percentage (float between 0.000001 and 0.99)."
+ },
+ "max_area": {
+ "label": "Maximum area of bounding box for object to be counted. Can be pixels (int) or percentage (float between 0.000001 and 0.99)."
+ },
+ "min_ratio": {
+ "label": "Minimum ratio of bounding box's width/height for object to be counted."
+ },
+ "max_ratio": {
+ "label": "Maximum ratio of bounding box's width/height for object to be counted."
+ },
+ "threshold": {
+ "label": "Average detection confidence threshold for object to be counted."
+ },
+ "min_score": {
+ "label": "Minimum detection confidence for object to be counted."
+ },
+ "mask": {
+ "label": "Detection area polygon mask for this filter configuration."
+ }
+ }
+ },
+ "mask": {
+ "label": "Object mask."
+ },
+ "genai": {
+ "label": "Config for using genai to analyze objects.",
+ "properties": {
+ "enabled": {
+ "label": "Enable GenAI for camera."
+ },
+ "use_snapshot": {
+ "label": "Use snapshots for generating descriptions."
+ },
+ "prompt": {
+ "label": "Default caption prompt."
+ },
+ "object_prompts": {
+ "label": "Object specific prompts."
+ },
+ "objects": {
+ "label": "List of objects to run generative AI for."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to run generative AI."
+ },
+ "debug_save_thumbnails": {
+ "label": "Save thumbnails sent to generative AI for debugging purposes."
+ },
+ "send_triggers": {
+ "label": "What triggers to use to send frames to generative AI for a tracked object.",
+ "properties": {
+ "tracked_object_end": {
+ "label": "Send once the object is no longer tracked."
+ },
+ "after_significant_updates": {
+ "label": "Send an early request to generative AI when X frames accumulated."
+ }
+ }
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of generative AI."
+ }
+ }
+ }
+ }
+ },
+ "record": {
+ "label": "Record configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable record on all cameras."
+ },
+ "sync_recordings": {
+ "label": "Sync recordings with disk on startup and once a day."
+ },
+ "expire_interval": {
+ "label": "Number of minutes to wait between cleanup runs."
+ },
+ "continuous": {
+ "label": "Continuous recording retention settings.",
+ "properties": {
+ "days": {
+ "label": "Default retention period."
+ }
+ }
+ },
+ "motion": {
+ "label": "Motion recording retention settings.",
+ "properties": {
+ "days": {
+ "label": "Default retention period."
+ }
+ }
+ },
+ "detections": {
+ "label": "Detection specific retention settings.",
+ "properties": {
+ "pre_capture": {
+ "label": "Seconds to retain before event starts."
+ },
+ "post_capture": {
+ "label": "Seconds to retain after event ends."
+ },
+ "retain": {
+ "label": "Event retention settings.",
+ "properties": {
+ "days": {
+ "label": "Default retention period."
+ },
+ "mode": {
+ "label": "Retain mode."
+ }
+ }
+ }
+ }
+ },
+ "alerts": {
+ "label": "Alert specific retention settings.",
+ "properties": {
+ "pre_capture": {
+ "label": "Seconds to retain before event starts."
+ },
+ "post_capture": {
+ "label": "Seconds to retain after event ends."
+ },
+ "retain": {
+ "label": "Event retention settings.",
+ "properties": {
+ "days": {
+ "label": "Default retention period."
+ },
+ "mode": {
+ "label": "Retain mode."
+ }
+ }
+ }
+ }
+ },
+ "export": {
+ "label": "Recording Export Config",
+ "properties": {
+ "timelapse_args": {
+ "label": "Timelapse Args"
+ }
+ }
+ },
+ "preview": {
+ "label": "Recording Preview Config",
+ "properties": {
+ "quality": {
+ "label": "Quality of recording preview."
+ }
+ }
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of recording."
+ }
+ }
+ },
+ "review": {
+ "label": "Review configuration.",
+ "properties": {
+ "alerts": {
+ "label": "Review alerts config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable alerts."
+ },
+ "labels": {
+ "label": "Labels to create alerts for."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to save the event as an alert."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of alerts."
+ },
+ "cutoff_time": {
+ "label": "Time to cutoff alerts after no alert-causing activity has occurred."
+ }
+ }
+ },
+ "detections": {
+ "label": "Review detections config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable detections."
+ },
+ "labels": {
+ "label": "Labels to create detections for."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to save the event as a detection."
+ },
+ "cutoff_time": {
+ "label": "Time to cutoff detection after no detection-causing activity has occurred."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of detections."
+ }
+ }
+ },
+ "genai": {
+ "label": "Review description genai config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable GenAI descriptions for review items."
+ },
+ "alerts": {
+ "label": "Enable GenAI for alerts."
+ },
+ "detections": {
+ "label": "Enable GenAI for detections."
+ },
+ "additional_concerns": {
+ "label": "Additional concerns that GenAI should make note of on this camera."
+ },
+ "debug_save_thumbnails": {
+ "label": "Save thumbnails sent to generative AI for debugging purposes."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of generative AI."
+ },
+ "preferred_language": {
+ "label": "Preferred language for GenAI Response"
+ },
+ "activity_context_prompt": {
+ "label": "Custom activity context prompt defining normal activity patterns for this property."
+ }
+ }
+ }
+ }
+ },
+ "semantic_search": {
+ "label": "Semantic search configuration.",
+ "properties": {
+ "triggers": {
+ "label": "Trigger actions on tracked objects that match existing thumbnails or descriptions",
+ "properties": {
+ "enabled": {
+ "label": "Enable this trigger"
+ },
+ "type": {
+ "label": "Type of trigger"
+ },
+ "data": {
+ "label": "Trigger content (text phrase or image ID)"
+ },
+ "threshold": {
+ "label": "Confidence score required to run the trigger"
+ },
+ "actions": {
+ "label": "Actions to perform when trigger is matched"
+ }
+ }
+ }
+ }
+ },
+ "snapshots": {
+ "label": "Snapshot configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Snapshots enabled."
+ },
+ "clean_copy": {
+ "label": "Create a clean copy of the snapshot image."
+ },
+ "timestamp": {
+ "label": "Add a timestamp overlay on the snapshot."
+ },
+ "bounding_box": {
+ "label": "Add a bounding box overlay on the snapshot."
+ },
+ "crop": {
+ "label": "Crop the snapshot to the detected object."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to save a snapshot."
+ },
+ "height": {
+ "label": "Snapshot image height."
+ },
+ "retain": {
+ "label": "Snapshot retention.",
+ "properties": {
+ "default": {
+ "label": "Default retention period."
+ },
+ "mode": {
+ "label": "Retain mode."
+ },
+ "objects": {
+ "label": "Object retention period."
+ }
+ }
+ },
+ "quality": {
+ "label": "Quality of the encoded jpeg (0-100)."
+ }
+ }
+ },
+ "timestamp_style": {
+ "label": "Timestamp style configuration.",
+ "properties": {
+ "position": {
+ "label": "Timestamp position."
+ },
+ "format": {
+ "label": "Timestamp format."
+ },
+ "color": {
+ "label": "Timestamp color.",
+ "properties": {
+ "red": {
+ "label": "Red"
+ },
+ "green": {
+ "label": "Green"
+ },
+ "blue": {
+ "label": "Blue"
+ }
+ }
+ },
+ "thickness": {
+ "label": "Timestamp thickness."
+ },
+ "effect": {
+ "label": "Timestamp effect."
+ }
+ }
+ },
+ "best_image_timeout": {
+ "label": "How long to wait for the image with the highest confidence score."
+ },
+ "mqtt": {
+ "label": "MQTT configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Send image over MQTT."
+ },
+ "timestamp": {
+ "label": "Add timestamp to MQTT image."
+ },
+ "bounding_box": {
+ "label": "Add bounding box to MQTT image."
+ },
+ "crop": {
+ "label": "Crop MQTT image to detected object."
+ },
+ "height": {
+ "label": "MQTT image height."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to send the image."
+ },
+ "quality": {
+ "label": "Quality of the encoded jpeg (0-100)."
+ }
+ }
+ },
+ "notifications": {
+ "label": "Notifications configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable notifications"
+ },
+ "email": {
+ "label": "Email required for push."
+ },
+ "cooldown": {
+ "label": "Cooldown period for notifications (time in seconds)."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of notifications."
+ }
+ }
+ },
+ "onvif": {
+ "label": "Camera Onvif Configuration.",
+ "properties": {
+ "host": {
+ "label": "Onvif Host"
+ },
+ "port": {
+ "label": "Onvif Port"
+ },
+ "user": {
+ "label": "Onvif Username"
+ },
+ "password": {
+ "label": "Onvif Password"
+ },
+ "tls_insecure": {
+ "label": "Onvif Disable TLS verification"
+ },
+ "autotracking": {
+ "label": "PTZ auto tracking config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable PTZ object autotracking."
+ },
+ "calibrate_on_startup": {
+ "label": "Perform a camera calibration when Frigate starts."
+ },
+ "zooming": {
+ "label": "Autotracker zooming mode."
+ },
+ "zoom_factor": {
+ "label": "Zooming factor (0.1-0.75)."
+ },
+ "track": {
+ "label": "Objects to track."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to begin autotracking."
+ },
+ "return_preset": {
+ "label": "Name of camera preset to return to when object tracking is over."
+ },
+ "timeout": {
+ "label": "Seconds to delay before returning to preset."
+ },
+ "movement_weights": {
+ "label": "Internal value used for PTZ movements based on the speed of your camera's motor."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of autotracking."
+ }
+ }
+ },
+ "ignore_time_mismatch": {
+ "label": "Onvif Ignore Time Synchronization Mismatch Between Camera and Server"
+ }
+ }
+ },
+ "type": {
+ "label": "Camera Type"
+ },
+ "ui": {
+ "label": "Camera UI Modifications.",
+ "properties": {
+ "order": {
+ "label": "Order of camera in UI."
+ },
+ "dashboard": {
+ "label": "Show this camera in Frigate dashboard UI."
+ }
+ }
+ },
+ "webui_url": {
+ "label": "URL to visit the camera directly from system page"
+ },
+ "zones": {
+ "label": "Zone configuration.",
+ "properties": {
+ "filters": {
+ "label": "Zone filters.",
+ "properties": {
+ "min_area": {
+ "label": "Minimum area of bounding box for object to be counted. Can be pixels (int) or percentage (float between 0.000001 and 0.99)."
+ },
+ "max_area": {
+ "label": "Maximum area of bounding box for object to be counted. Can be pixels (int) or percentage (float between 0.000001 and 0.99)."
+ },
+ "min_ratio": {
+ "label": "Minimum ratio of bounding box's width/height for object to be counted."
+ },
+ "max_ratio": {
+ "label": "Maximum ratio of bounding box's width/height for object to be counted."
+ },
+ "threshold": {
+ "label": "Average detection confidence threshold for object to be counted."
+ },
+ "min_score": {
+ "label": "Minimum detection confidence for object to be counted."
+ },
+ "mask": {
+ "label": "Detection area polygon mask for this filter configuration."
+ }
+ }
+ },
+ "coordinates": {
+ "label": "Coordinates polygon for the defined zone."
+ },
+ "distances": {
+ "label": "Real-world distances for the sides of quadrilateral for the defined zone."
+ },
+ "inertia": {
+ "label": "Number of consecutive frames required for object to be considered present in the zone."
+ },
+ "loitering_time": {
+ "label": "Number of seconds that an object must loiter to be considered in the zone."
+ },
+ "speed_threshold": {
+ "label": "Minimum speed value for an object to be considered in the zone."
+ },
+ "objects": {
+ "label": "List of objects that can trigger the zone."
+ }
+ }
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of camera."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/classification.json b/web/public/locales/en/config/classification.json
new file mode 100644
index 000000000..e8014b2fa
--- /dev/null
+++ b/web/public/locales/en/config/classification.json
@@ -0,0 +1,58 @@
+{
+ "label": "Object classification config.",
+ "properties": {
+ "bird": {
+ "label": "Bird classification config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable bird classification."
+ },
+ "threshold": {
+ "label": "Minimum classification score required to be considered a match."
+ }
+ }
+ },
+ "custom": {
+ "label": "Custom Classification Model Configs.",
+ "properties": {
+ "enabled": {
+ "label": "Enable running the model."
+ },
+ "name": {
+ "label": "Name of classification model."
+ },
+ "threshold": {
+ "label": "Classification score threshold to change the state."
+ },
+ "object_config": {
+ "properties": {
+ "objects": {
+ "label": "Object types to classify."
+ },
+ "classification_type": {
+ "label": "Type of classification that is applied."
+ }
+ }
+ },
+ "state_config": {
+ "properties": {
+ "cameras": {
+ "label": "Cameras to run classification on.",
+ "properties": {
+ "crop": {
+ "label": "Crop of image frame on this camera to run classification on."
+ }
+ }
+ },
+ "motion": {
+ "label": "If classification should be run when motion is detected in the crop."
+ },
+ "interval": {
+ "label": "Interval to run classification on in seconds."
+ }
+ }
+ }
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/database.json b/web/public/locales/en/config/database.json
new file mode 100644
index 000000000..ece7ccbaa
--- /dev/null
+++ b/web/public/locales/en/config/database.json
@@ -0,0 +1,8 @@
+{
+ "label": "Database configuration.",
+ "properties": {
+ "path": {
+ "label": "Database path."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/detect.json b/web/public/locales/en/config/detect.json
new file mode 100644
index 000000000..9e1b59313
--- /dev/null
+++ b/web/public/locales/en/config/detect.json
@@ -0,0 +1,51 @@
+{
+ "label": "Global object tracking configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Detection Enabled."
+ },
+ "height": {
+ "label": "Height of the stream for the detect role."
+ },
+ "width": {
+ "label": "Width of the stream for the detect role."
+ },
+ "fps": {
+ "label": "Number of frames per second to process through detection."
+ },
+ "min_initialized": {
+ "label": "Minimum number of consecutive hits for an object to be initialized by the tracker."
+ },
+ "max_disappeared": {
+ "label": "Maximum number of frames the object can disappear before detection ends."
+ },
+ "stationary": {
+ "label": "Stationary objects config.",
+ "properties": {
+ "interval": {
+ "label": "Frame interval for checking stationary objects."
+ },
+ "threshold": {
+ "label": "Number of frames without a position change for an object to be considered stationary"
+ },
+ "max_frames": {
+ "label": "Max frames for stationary objects.",
+ "properties": {
+ "default": {
+ "label": "Default max frames."
+ },
+ "objects": {
+ "label": "Object specific max frames."
+ }
+ }
+ },
+ "classifier": {
+ "label": "Enable visual classifier for determing if objects with jittery bounding boxes are stationary."
+ }
+ }
+ },
+ "annotation_offset": {
+ "label": "Milliseconds to offset detect annotations by."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/detectors.json b/web/public/locales/en/config/detectors.json
new file mode 100644
index 000000000..1bd6fec70
--- /dev/null
+++ b/web/public/locales/en/config/detectors.json
@@ -0,0 +1,14 @@
+{
+ "label": "Detector hardware configuration.",
+ "properties": {
+ "type": {
+ "label": "Detector Type"
+ },
+ "model": {
+ "label": "Detector specific model configuration."
+ },
+ "model_path": {
+ "label": "Detector specific model path."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/environment_vars.json b/web/public/locales/en/config/environment_vars.json
new file mode 100644
index 000000000..ce97ce49e
--- /dev/null
+++ b/web/public/locales/en/config/environment_vars.json
@@ -0,0 +1,3 @@
+{
+ "label": "Frigate environment variables."
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/face_recognition.json b/web/public/locales/en/config/face_recognition.json
new file mode 100644
index 000000000..705d75468
--- /dev/null
+++ b/web/public/locales/en/config/face_recognition.json
@@ -0,0 +1,36 @@
+{
+ "label": "Face recognition config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable face recognition."
+ },
+ "model_size": {
+ "label": "The size of the embeddings model used."
+ },
+ "unknown_score": {
+ "label": "Minimum face distance score required to be marked as a potential match."
+ },
+ "detection_threshold": {
+ "label": "Minimum face detection score required to be considered a face."
+ },
+ "recognition_threshold": {
+ "label": "Minimum face distance score required to be considered a match."
+ },
+ "min_area": {
+ "label": "Min area of face box to consider running face recognition."
+ },
+ "min_faces": {
+ "label": "Min face recognitions for the sub label to be applied to the person object."
+ },
+ "save_attempts": {
+ "label": "Number of face attempts to save in the recent recognitions tab."
+ },
+ "blur_confidence_filter": {
+ "label": "Apply blur quality filter to face confidence."
+ },
+ "device": {
+ "label": "The device key to use for face recognition.",
+ "description": "This is an override, to target a specific device. See https://onnxruntime.ai/docs/execution-providers/ for more information"
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/ffmpeg.json b/web/public/locales/en/config/ffmpeg.json
new file mode 100644
index 000000000..570da5a35
--- /dev/null
+++ b/web/public/locales/en/config/ffmpeg.json
@@ -0,0 +1,34 @@
+{
+ "label": "Global FFmpeg configuration.",
+ "properties": {
+ "path": {
+ "label": "FFmpeg path"
+ },
+ "global_args": {
+ "label": "Global FFmpeg arguments."
+ },
+ "hwaccel_args": {
+ "label": "FFmpeg hardware acceleration arguments."
+ },
+ "input_args": {
+ "label": "FFmpeg input arguments."
+ },
+ "output_args": {
+ "label": "FFmpeg output arguments per role.",
+ "properties": {
+ "detect": {
+ "label": "Detect role FFmpeg output arguments."
+ },
+ "record": {
+ "label": "Record role FFmpeg output arguments."
+ }
+ }
+ },
+ "retry_interval": {
+ "label": "Time in seconds to wait before FFmpeg retries connecting to the camera."
+ },
+ "apple_compatibility": {
+ "label": "Set tag on HEVC (H.265) recording stream to improve compatibility with Apple players."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/genai.json b/web/public/locales/en/config/genai.json
new file mode 100644
index 000000000..fed679d9e
--- /dev/null
+++ b/web/public/locales/en/config/genai.json
@@ -0,0 +1,23 @@
+{
+ "label": "Generative AI configuration.",
+ "properties": {
+ "api_key": {
+ "label": "Provider API key."
+ },
+ "base_url": {
+ "label": "Provider base url."
+ },
+ "model": {
+ "label": "GenAI model."
+ },
+ "provider": {
+ "label": "GenAI provider."
+ },
+ "provider_options": {
+ "label": "GenAI Provider extra options."
+ },
+ "runtime_options": {
+ "label": "Options to pass during inference calls."
+ }
+ }
+}
diff --git a/web/public/locales/en/config/go2rtc.json b/web/public/locales/en/config/go2rtc.json
new file mode 100644
index 000000000..76ec33020
--- /dev/null
+++ b/web/public/locales/en/config/go2rtc.json
@@ -0,0 +1,3 @@
+{
+ "label": "Global restream configuration."
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/live.json b/web/public/locales/en/config/live.json
new file mode 100644
index 000000000..362170137
--- /dev/null
+++ b/web/public/locales/en/config/live.json
@@ -0,0 +1,14 @@
+{
+ "label": "Live playback settings.",
+ "properties": {
+ "streams": {
+ "label": "Friendly names and restream names to use for live view."
+ },
+ "height": {
+ "label": "Live camera view height"
+ },
+ "quality": {
+ "label": "Live camera view quality"
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/logger.json b/web/public/locales/en/config/logger.json
new file mode 100644
index 000000000..3d51786a7
--- /dev/null
+++ b/web/public/locales/en/config/logger.json
@@ -0,0 +1,11 @@
+{
+ "label": "Logging configuration.",
+ "properties": {
+ "default": {
+ "label": "Default logging level."
+ },
+ "logs": {
+ "label": "Log level for specified processes."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/lpr.json b/web/public/locales/en/config/lpr.json
new file mode 100644
index 000000000..951d1f8f6
--- /dev/null
+++ b/web/public/locales/en/config/lpr.json
@@ -0,0 +1,45 @@
+{
+ "label": "License Plate recognition config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable license plate recognition."
+ },
+ "model_size": {
+ "label": "The size of the embeddings model used."
+ },
+ "detection_threshold": {
+ "label": "License plate object confidence score required to begin running recognition."
+ },
+ "min_area": {
+ "label": "Minimum area of license plate to begin running recognition."
+ },
+ "recognition_threshold": {
+ "label": "Recognition confidence score required to add the plate to the object as a sub label."
+ },
+ "min_plate_length": {
+ "label": "Minimum number of characters a license plate must have to be added to the object as a sub label."
+ },
+ "format": {
+ "label": "Regular expression for the expected format of license plate."
+ },
+ "match_distance": {
+ "label": "Allow this number of missing/incorrect characters to still cause a detected plate to match a known plate."
+ },
+ "known_plates": {
+ "label": "Known plates to track (strings or regular expressions)."
+ },
+ "enhancement": {
+ "label": "Amount of contrast adjustment and denoising to apply to license plate images before recognition."
+ },
+ "debug_save_plates": {
+ "label": "Save plates captured for LPR for debugging purposes."
+ },
+ "device": {
+ "label": "The device key to use for LPR.",
+ "description": "This is an override, to target a specific device. See https://onnxruntime.ai/docs/execution-providers/ for more information"
+ },
+ "replace_rules": {
+ "label": "List of regex replacement rules for normalizing detected plates. Each rule has 'pattern' and 'replacement'."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/model.json b/web/public/locales/en/config/model.json
new file mode 100644
index 000000000..0bc2c1ddf
--- /dev/null
+++ b/web/public/locales/en/config/model.json
@@ -0,0 +1,35 @@
+{
+ "label": "Detection model configuration.",
+ "properties": {
+ "path": {
+ "label": "Custom Object detection model path."
+ },
+ "labelmap_path": {
+ "label": "Label map for custom object detector."
+ },
+ "width": {
+ "label": "Object detection model input width."
+ },
+ "height": {
+ "label": "Object detection model input height."
+ },
+ "labelmap": {
+ "label": "Labelmap customization."
+ },
+ "attributes_map": {
+ "label": "Map of object labels to their attribute labels."
+ },
+ "input_tensor": {
+ "label": "Model Input Tensor Shape"
+ },
+ "input_pixel_format": {
+ "label": "Model Input Pixel Color Format"
+ },
+ "input_dtype": {
+ "label": "Model Input D Type"
+ },
+ "model_type": {
+ "label": "Object Detection Model Type"
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/motion.json b/web/public/locales/en/config/motion.json
new file mode 100644
index 000000000..183bfdf34
--- /dev/null
+++ b/web/public/locales/en/config/motion.json
@@ -0,0 +1,3 @@
+{
+ "label": "Global motion detection configuration."
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/mqtt.json b/web/public/locales/en/config/mqtt.json
new file mode 100644
index 000000000..d2625ac83
--- /dev/null
+++ b/web/public/locales/en/config/mqtt.json
@@ -0,0 +1,44 @@
+{
+ "label": "MQTT configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable MQTT Communication."
+ },
+ "host": {
+ "label": "MQTT Host"
+ },
+ "port": {
+ "label": "MQTT Port"
+ },
+ "topic_prefix": {
+ "label": "MQTT Topic Prefix"
+ },
+ "client_id": {
+ "label": "MQTT Client ID"
+ },
+ "stats_interval": {
+ "label": "MQTT Camera Stats Interval"
+ },
+ "user": {
+ "label": "MQTT Username"
+ },
+ "password": {
+ "label": "MQTT Password"
+ },
+ "tls_ca_certs": {
+ "label": "MQTT TLS CA Certificates"
+ },
+ "tls_client_cert": {
+ "label": "MQTT TLS Client Certificate"
+ },
+ "tls_client_key": {
+ "label": "MQTT TLS Client Key"
+ },
+ "tls_insecure": {
+ "label": "MQTT TLS Insecure"
+ },
+ "qos": {
+ "label": "MQTT QoS"
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/networking.json b/web/public/locales/en/config/networking.json
new file mode 100644
index 000000000..0f8d9cc54
--- /dev/null
+++ b/web/public/locales/en/config/networking.json
@@ -0,0 +1,13 @@
+{
+ "label": "Networking configuration",
+ "properties": {
+ "ipv6": {
+ "label": "Network configuration",
+ "properties": {
+ "enabled": {
+ "label": "Enable IPv6 for port 5000 and/or 8971"
+ }
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/notifications.json b/web/public/locales/en/config/notifications.json
new file mode 100644
index 000000000..b529f10e0
--- /dev/null
+++ b/web/public/locales/en/config/notifications.json
@@ -0,0 +1,17 @@
+{
+ "label": "Global notification configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable notifications"
+ },
+ "email": {
+ "label": "Email required for push."
+ },
+ "cooldown": {
+ "label": "Cooldown period for notifications (time in seconds)."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of notifications."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/objects.json b/web/public/locales/en/config/objects.json
new file mode 100644
index 000000000..f041672a0
--- /dev/null
+++ b/web/public/locales/en/config/objects.json
@@ -0,0 +1,77 @@
+{
+ "label": "Global object configuration.",
+ "properties": {
+ "track": {
+ "label": "Objects to track."
+ },
+ "filters": {
+ "label": "Object filters.",
+ "properties": {
+ "min_area": {
+ "label": "Minimum area of bounding box for object to be counted. Can be pixels (int) or percentage (float between 0.000001 and 0.99)."
+ },
+ "max_area": {
+ "label": "Maximum area of bounding box for object to be counted. Can be pixels (int) or percentage (float between 0.000001 and 0.99)."
+ },
+ "min_ratio": {
+ "label": "Minimum ratio of bounding box's width/height for object to be counted."
+ },
+ "max_ratio": {
+ "label": "Maximum ratio of bounding box's width/height for object to be counted."
+ },
+ "threshold": {
+ "label": "Average detection confidence threshold for object to be counted."
+ },
+ "min_score": {
+ "label": "Minimum detection confidence for object to be counted."
+ },
+ "mask": {
+ "label": "Detection area polygon mask for this filter configuration."
+ }
+ }
+ },
+ "mask": {
+ "label": "Object mask."
+ },
+ "genai": {
+ "label": "Config for using genai to analyze objects.",
+ "properties": {
+ "enabled": {
+ "label": "Enable GenAI for camera."
+ },
+ "use_snapshot": {
+ "label": "Use snapshots for generating descriptions."
+ },
+ "prompt": {
+ "label": "Default caption prompt."
+ },
+ "object_prompts": {
+ "label": "Object specific prompts."
+ },
+ "objects": {
+ "label": "List of objects to run generative AI for."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to run generative AI."
+ },
+ "debug_save_thumbnails": {
+ "label": "Save thumbnails sent to generative AI for debugging purposes."
+ },
+ "send_triggers": {
+ "label": "What triggers to use to send frames to generative AI for a tracked object.",
+ "properties": {
+ "tracked_object_end": {
+ "label": "Send once the object is no longer tracked."
+ },
+ "after_significant_updates": {
+ "label": "Send an early request to generative AI when X frames accumulated."
+ }
+ }
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of generative AI."
+ }
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/proxy.json b/web/public/locales/en/config/proxy.json
new file mode 100644
index 000000000..732d6fafd
--- /dev/null
+++ b/web/public/locales/en/config/proxy.json
@@ -0,0 +1,31 @@
+{
+ "label": "Proxy configuration.",
+ "properties": {
+ "header_map": {
+ "label": "Header mapping definitions for proxy user passing.",
+ "properties": {
+ "user": {
+ "label": "Header name from upstream proxy to identify user."
+ },
+ "role": {
+ "label": "Header name from upstream proxy to identify user role."
+ },
+ "role_map": {
+ "label": "Mapping of Frigate roles to upstream group values. "
+ }
+ }
+ },
+ "logout_url": {
+ "label": "Redirect url for logging out with proxy."
+ },
+ "auth_secret": {
+ "label": "Secret value for proxy authentication."
+ },
+ "default_role": {
+ "label": "Default role for proxy users."
+ },
+ "separator": {
+ "label": "The character used to separate values in a mapped header."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/record.json b/web/public/locales/en/config/record.json
new file mode 100644
index 000000000..81139084e
--- /dev/null
+++ b/web/public/locales/en/config/record.json
@@ -0,0 +1,93 @@
+{
+ "label": "Global record configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable record on all cameras."
+ },
+ "sync_recordings": {
+ "label": "Sync recordings with disk on startup and once a day."
+ },
+ "expire_interval": {
+ "label": "Number of minutes to wait between cleanup runs."
+ },
+ "continuous": {
+ "label": "Continuous recording retention settings.",
+ "properties": {
+ "days": {
+ "label": "Default retention period."
+ }
+ }
+ },
+ "motion": {
+ "label": "Motion recording retention settings.",
+ "properties": {
+ "days": {
+ "label": "Default retention period."
+ }
+ }
+ },
+ "detections": {
+ "label": "Detection specific retention settings.",
+ "properties": {
+ "pre_capture": {
+ "label": "Seconds to retain before event starts."
+ },
+ "post_capture": {
+ "label": "Seconds to retain after event ends."
+ },
+ "retain": {
+ "label": "Event retention settings.",
+ "properties": {
+ "days": {
+ "label": "Default retention period."
+ },
+ "mode": {
+ "label": "Retain mode."
+ }
+ }
+ }
+ }
+ },
+ "alerts": {
+ "label": "Alert specific retention settings.",
+ "properties": {
+ "pre_capture": {
+ "label": "Seconds to retain before event starts."
+ },
+ "post_capture": {
+ "label": "Seconds to retain after event ends."
+ },
+ "retain": {
+ "label": "Event retention settings.",
+ "properties": {
+ "days": {
+ "label": "Default retention period."
+ },
+ "mode": {
+ "label": "Retain mode."
+ }
+ }
+ }
+ }
+ },
+ "export": {
+ "label": "Recording Export Config",
+ "properties": {
+ "timelapse_args": {
+ "label": "Timelapse Args"
+ }
+ }
+ },
+ "preview": {
+ "label": "Recording Preview Config",
+ "properties": {
+ "quality": {
+ "label": "Quality of recording preview."
+ }
+ }
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of recording."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/review.json b/web/public/locales/en/config/review.json
new file mode 100644
index 000000000..dba83ee1c
--- /dev/null
+++ b/web/public/locales/en/config/review.json
@@ -0,0 +1,74 @@
+{
+ "label": "Review configuration.",
+ "properties": {
+ "alerts": {
+ "label": "Review alerts config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable alerts."
+ },
+ "labels": {
+ "label": "Labels to create alerts for."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to save the event as an alert."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of alerts."
+ },
+ "cutoff_time": {
+ "label": "Time to cutoff alerts after no alert-causing activity has occurred."
+ }
+ }
+ },
+ "detections": {
+ "label": "Review detections config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable detections."
+ },
+ "labels": {
+ "label": "Labels to create detections for."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to save the event as a detection."
+ },
+ "cutoff_time": {
+ "label": "Time to cutoff detection after no detection-causing activity has occurred."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of detections."
+ }
+ }
+ },
+ "genai": {
+ "label": "Review description genai config.",
+ "properties": {
+ "enabled": {
+ "label": "Enable GenAI descriptions for review items."
+ },
+ "alerts": {
+ "label": "Enable GenAI for alerts."
+ },
+ "detections": {
+ "label": "Enable GenAI for detections."
+ },
+ "additional_concerns": {
+ "label": "Additional concerns that GenAI should make note of on this camera."
+ },
+ "debug_save_thumbnails": {
+ "label": "Save thumbnails sent to generative AI for debugging purposes."
+ },
+ "enabled_in_config": {
+ "label": "Keep track of original state of generative AI."
+ },
+ "preferred_language": {
+ "label": "Preferred language for GenAI Response"
+ },
+ "activity_context_prompt": {
+ "label": "Custom activity context prompt defining normal activity patterns for this property."
+ }
+ }
+ }
+ }
+}
diff --git a/web/public/locales/en/config/safe_mode.json b/web/public/locales/en/config/safe_mode.json
new file mode 100644
index 000000000..352f78b29
--- /dev/null
+++ b/web/public/locales/en/config/safe_mode.json
@@ -0,0 +1,3 @@
+{
+ "label": "If Frigate should be started in safe mode."
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/semantic_search.json b/web/public/locales/en/config/semantic_search.json
new file mode 100644
index 000000000..2c46640bb
--- /dev/null
+++ b/web/public/locales/en/config/semantic_search.json
@@ -0,0 +1,21 @@
+{
+ "label": "Semantic search configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable semantic search."
+ },
+ "reindex": {
+ "label": "Reindex all tracked objects on startup."
+ },
+ "model": {
+ "label": "The CLIP model to use for semantic search."
+ },
+ "model_size": {
+ "label": "The size of the embeddings model used."
+ },
+ "device": {
+ "label": "The device key to use for semantic search.",
+ "description": "This is an override, to target a specific device. See https://onnxruntime.ai/docs/execution-providers/ for more information"
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/snapshots.json b/web/public/locales/en/config/snapshots.json
new file mode 100644
index 000000000..a6336140e
--- /dev/null
+++ b/web/public/locales/en/config/snapshots.json
@@ -0,0 +1,43 @@
+{
+ "label": "Global snapshots configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Snapshots enabled."
+ },
+ "clean_copy": {
+ "label": "Create a clean copy of the snapshot image."
+ },
+ "timestamp": {
+ "label": "Add a timestamp overlay on the snapshot."
+ },
+ "bounding_box": {
+ "label": "Add a bounding box overlay on the snapshot."
+ },
+ "crop": {
+ "label": "Crop the snapshot to the detected object."
+ },
+ "required_zones": {
+ "label": "List of required zones to be entered in order to save a snapshot."
+ },
+ "height": {
+ "label": "Snapshot image height."
+ },
+ "retain": {
+ "label": "Snapshot retention.",
+ "properties": {
+ "default": {
+ "label": "Default retention period."
+ },
+ "mode": {
+ "label": "Retain mode."
+ },
+ "objects": {
+ "label": "Object retention period."
+ }
+ }
+ },
+ "quality": {
+ "label": "Quality of the encoded jpeg (0-100)."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/telemetry.json b/web/public/locales/en/config/telemetry.json
new file mode 100644
index 000000000..802ced2a0
--- /dev/null
+++ b/web/public/locales/en/config/telemetry.json
@@ -0,0 +1,28 @@
+{
+ "label": "Telemetry configuration.",
+ "properties": {
+ "network_interfaces": {
+ "label": "Enabled network interfaces for bandwidth calculation."
+ },
+ "stats": {
+ "label": "System Stats Configuration",
+ "properties": {
+ "amd_gpu_stats": {
+ "label": "Enable AMD GPU stats."
+ },
+ "intel_gpu_stats": {
+ "label": "Enable Intel GPU stats."
+ },
+ "network_bandwidth": {
+ "label": "Enable network bandwidth for ffmpeg processes."
+ },
+ "intel_gpu_device": {
+ "label": "Define the device to use when gathering SR-IOV stats."
+ }
+ }
+ },
+ "version_check": {
+ "label": "Enable latest version check."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/timestamp_style.json b/web/public/locales/en/config/timestamp_style.json
new file mode 100644
index 000000000..6a3119423
--- /dev/null
+++ b/web/public/locales/en/config/timestamp_style.json
@@ -0,0 +1,31 @@
+{
+ "label": "Global timestamp style configuration.",
+ "properties": {
+ "position": {
+ "label": "Timestamp position."
+ },
+ "format": {
+ "label": "Timestamp format."
+ },
+ "color": {
+ "label": "Timestamp color.",
+ "properties": {
+ "red": {
+ "label": "Red"
+ },
+ "green": {
+ "label": "Green"
+ },
+ "blue": {
+ "label": "Blue"
+ }
+ }
+ },
+ "thickness": {
+ "label": "Timestamp thickness."
+ },
+ "effect": {
+ "label": "Timestamp effect."
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/tls.json b/web/public/locales/en/config/tls.json
new file mode 100644
index 000000000..58493ff40
--- /dev/null
+++ b/web/public/locales/en/config/tls.json
@@ -0,0 +1,8 @@
+{
+ "label": "TLS configuration.",
+ "properties": {
+ "enabled": {
+ "label": "Enable TLS for port 8971"
+ }
+ }
+}
\ No newline at end of file
diff --git a/web/public/locales/en/config/ui.json b/web/public/locales/en/config/ui.json
new file mode 100644
index 000000000..cdd91cb53
--- /dev/null
+++ b/web/public/locales/en/config/ui.json
@@ -0,0 +1,20 @@
+{
+ "label": "UI configuration.",
+ "properties": {
+ "timezone": {
+ "label": "Override UI timezone."
+ },
+ "time_format": {
+ "label": "Override UI time format."
+ },
+ "date_style": {
+ "label": "Override UI dateStyle."
+ },
+ "time_style": {
+ "label": "Override UI timeStyle."
+ },
+ "unit_system": {
+ "label": "The unit system to use for measurements."
+ }
+ }
+}
diff --git a/web/public/locales/en/config/version.json b/web/public/locales/en/config/version.json
new file mode 100644
index 000000000..e777d7573
--- /dev/null
+++ b/web/public/locales/en/config/version.json
@@ -0,0 +1,3 @@
+{
+ "label": "Current config version."
+}
\ No newline at end of file
diff --git a/web/public/locales/en/views/classificationModel.json b/web/public/locales/en/views/classificationModel.json
new file mode 100644
index 000000000..a07114b5c
--- /dev/null
+++ b/web/public/locales/en/views/classificationModel.json
@@ -0,0 +1,187 @@
+{
+ "documentTitle": "Classification Models - Frigate",
+ "details": {
+ "scoreInfo": "Score represents the average classification confidence across all detections of this object.",
+ "none": "None",
+ "unknown": "Unknown"
+ },
+ "button": {
+ "deleteClassificationAttempts": "Delete Classification Images",
+ "renameCategory": "Rename Class",
+ "deleteCategory": "Delete Class",
+ "deleteImages": "Delete Images",
+ "trainModel": "Train Model",
+ "addClassification": "Add Classification",
+ "deleteModels": "Delete Models",
+ "editModel": "Edit Model"
+ },
+ "tooltip": {
+ "trainingInProgress": "Model is currently training",
+ "noNewImages": "No new images to train. Classify more images in the dataset first.",
+ "noChanges": "No changes to the dataset since last training.",
+ "modelNotReady": "Model is not ready for training"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Deleted Class",
+ "deletedImage": "Deleted Images",
+ "deletedModel_one": "Successfully deleted {{count}} model",
+ "deletedModel_other": "Successfully deleted {{count}} models",
+ "categorizedImage": "Successfully Classified Image",
+ "trainedModel": "Successfully trained model.",
+ "trainingModel": "Successfully started model training.",
+ "updatedModel": "Successfully updated model configuration",
+ "renamedCategory": "Successfully renamed class to {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Failed to delete: {{errorMessage}}",
+ "deleteCategoryFailed": "Failed to delete class: {{errorMessage}}",
+ "deleteModelFailed": "Failed to delete model: {{errorMessage}}",
+ "categorizeFailed": "Failed to categorize image: {{errorMessage}}",
+ "trainingFailed": "Model training failed. Check Frigate logs for details.",
+ "trainingFailedToStart": "Failed to start model training: {{errorMessage}}",
+ "updateModelFailed": "Failed to update model: {{errorMessage}}",
+ "renameCategoryFailed": "Failed to rename class: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Delete Class",
+ "desc": "Are you sure you want to delete the class {{name}}? This will permanently delete all associated images and require re-training the model.",
+ "minClassesTitle": "Cannot Delete Class",
+ "minClassesDesc": "A classification model must have at least 2 classes. Add another class before deleting this one."
+ },
+ "deleteModel": {
+ "title": "Delete Classification Model",
+ "single": "Are you sure you want to delete {{name}}? This will permanently delete all associated data including images and training data. This action cannot be undone.",
+ "desc_one": "Are you sure you want to delete {{count}} model? This will permanently delete all associated data including images and training data. This action cannot be undone.",
+ "desc_other": "Are you sure you want to delete {{count}} models? This will permanently delete all associated data including images and training data. This action cannot be undone."
+ },
+ "edit": {
+ "title": "Edit Classification Model",
+ "descriptionState": "Edit the classes for this state classification model. Changes will require retraining the model.",
+ "descriptionObject": "Edit the object type and classification type for this object classification model.",
+ "stateClassesInfo": "Note: Changing state classes requires retraining the model with the updated classes."
+ },
+ "deleteDatasetImages": {
+ "title": "Delete Dataset Images",
+ "desc_one": "Are you sure you want to delete {{count}} image from {{dataset}}? This action cannot be undone and will require re-training the model.",
+ "desc_other": "Are you sure you want to delete {{count}} images from {{dataset}}? This action cannot be undone and will require re-training the model."
+ },
+ "deleteTrainImages": {
+ "title": "Delete Train Images",
+ "desc_one": "Are you sure you want to delete {{count}} image? This action cannot be undone.",
+ "desc_other": "Are you sure you want to delete {{count}} images? This action cannot be undone."
+ },
+ "renameCategory": {
+ "title": "Rename Class",
+ "desc": "Enter a new name for {{name}}. You will be required to retrain the model for the name change to take effect."
+ },
+ "description": {
+ "invalidName": "Invalid name. Names can only include letters, numbers, spaces, apostrophes, underscores, and hyphens."
+ },
+ "train": {
+ "title": "Recent Classifications",
+ "titleShort": "Recent",
+ "aria": "Select Recent Classifications"
+ },
+ "categories": "Classes",
+ "createCategory": {
+ "new": "Create New Class"
+ },
+ "categorizeImageAs": "Classify Image As:",
+ "categorizeImage": "Classify Image",
+ "menu": {
+ "objects": "Objects",
+ "states": "States"
+ },
+ "noModels": {
+ "object": {
+ "title": "No Object Classification Models",
+ "description": "Create a custom model to classify detected objects.",
+ "buttonText": "Create Object Model"
+ },
+ "state": {
+ "title": "No State Classification Models",
+ "description": "Create a custom model to monitor and classify state changes in specific camera areas.",
+ "buttonText": "Create State Model"
+ }
+ },
+ "wizard": {
+ "title": "Create New Classification",
+ "steps": {
+ "nameAndDefine": "Name & Define",
+ "stateArea": "State Area",
+ "chooseExamples": "Choose Examples"
+ },
+ "step1": {
+ "description": "State models monitor fixed camera areas for changes (e.g., door open/closed). Object models add classifications to detected objects (e.g., known animals, delivery persons, etc.).",
+ "name": "Name",
+ "namePlaceholder": "Enter model name...",
+ "type": "Type",
+ "typeState": "State",
+ "typeObject": "Object",
+ "objectLabel": "Object Label",
+ "objectLabelPlaceholder": "Select object type...",
+ "classificationType": "Classification Type",
+ "classificationTypeTip": "Learn about classification types",
+ "classificationTypeDesc": "Sub Labels add additional text to the object label (e.g., 'Person: UPS'). Attributes are searchable metadata stored separately in the object metadata.",
+ "classificationSubLabel": "Sub Label",
+ "classificationAttribute": "Attribute",
+ "classes": "Classes",
+ "states": "States",
+ "classesTip": "Learn about classes",
+ "classesStateDesc": "Define the different states your camera area can be in. For example: 'open' and 'closed' for a garage door.",
+ "classesObjectDesc": "Define the different categories to classify detected objects into. For example: 'delivery_person', 'resident', 'stranger' for person classification.",
+ "classPlaceholder": "Enter class name...",
+ "errors": {
+ "nameRequired": "Model name is required",
+ "nameLength": "Model name must be 64 characters or less",
+ "nameOnlyNumbers": "Model name cannot contain only numbers",
+ "classRequired": "At least 1 class is required",
+ "classesUnique": "Class names must be unique",
+ "noneNotAllowed": "The class 'none' is not allowed",
+ "stateRequiresTwoClasses": "State models require at least 2 classes",
+ "objectLabelRequired": "Please select an object label",
+ "objectTypeRequired": "Please select a classification type"
+ }
+ },
+ "step2": {
+ "description": "Select cameras and define the area to monitor for each camera. The model will classify the state of these areas.",
+ "cameras": "Cameras",
+ "selectCamera": "Select Camera",
+ "noCameras": "Click + to add cameras",
+ "selectCameraPrompt": "Select a camera from the list to define its monitoring area"
+ },
+ "step3": {
+ "selectImagesPrompt": "Select all images with: {{className}}",
+ "selectImagesDescription": "Click on images to select them. Click Continue when you're done with this class.",
+ "allImagesRequired_one": "Please classify all images. {{count}} image remaining.",
+ "allImagesRequired_other": "Please classify all images. {{count}} images remaining.",
+ "generating": {
+ "title": "Generating Sample Images",
+ "description": "Frigate is pulling representative images from your recordings. This may take a moment..."
+ },
+ "training": {
+ "title": "Training Model",
+ "description": "Your model is being trained in the background. Close this dialog, and your model will start running as soon as training is complete."
+ },
+ "retryGenerate": "Retry Generation",
+ "noImages": "No sample images generated",
+ "classifying": "Classifying & Training...",
+ "trainingStarted": "Training started successfully",
+ "modelCreated": "Model created successfully. Use the Recent Classifications view to add images for missing states, then train the model.",
+ "errors": {
+ "noCameras": "No cameras configured",
+ "noObjectLabel": "No object label selected",
+ "generateFailed": "Failed to generate examples: {{error}}",
+ "generationFailed": "Generation failed. Please try again.",
+ "classifyFailed": "Failed to classify images: {{error}}"
+ },
+ "generateSuccess": "Successfully generated sample images",
+ "missingStatesWarning": {
+ "title": "Missing State Examples",
+ "description": "It's recommended to select examples for all states for best results. You can continue without selecting all states, but the model will not be trained until all states have images. After continuing, use the Recent Classifications view to classify images for the missing states, then train the model."
+ }
+ }
+ }
+}
diff --git a/web/public/locales/en/views/configEditor.json b/web/public/locales/en/views/configEditor.json
index ef3035f38..614143c16 100644
--- a/web/public/locales/en/views/configEditor.json
+++ b/web/public/locales/en/views/configEditor.json
@@ -1,6 +1,8 @@
{
"documentTitle": "Config Editor - Frigate",
"configEditor": "Config Editor",
+ "safeConfigEditor": "Config Editor (Safe Mode)",
+ "safeModeDescription": "Frigate is in safe mode due to a config validation error.",
"copyConfig": "Copy Config",
"saveAndRestart": "Save & Restart",
"saveOnly": "Save Only",
diff --git a/web/public/locales/en/views/events.json b/web/public/locales/en/views/events.json
index 98bc7c422..ea3ee853d 100644
--- a/web/public/locales/en/views/events.json
+++ b/web/public/locales/en/views/events.json
@@ -9,15 +9,38 @@
"empty": {
"alert": "There are no alerts to review",
"detection": "There are no detections to review",
- "motion": "No motion data found"
+ "motion": "No motion data found",
+ "recordingsDisabled": {
+ "title": "Recordings must be enabled",
+ "description": "Review items can only be created for a camera when recordings are enabled for that camera."
+ }
},
"timeline": "Timeline",
"timeline.aria": "Select timeline",
+ "zoomIn": "Zoom In",
+ "zoomOut": "Zoom Out",
"events": {
"label": "Events",
"aria": "Select events",
"noFoundForTimePeriod": "No events found for this time period."
},
+ "detail": {
+ "label": "Detail",
+ "noDataFound": "No detail data to review",
+ "aria": "Toggle detail view",
+ "trackedObject_one": "{{count}} object",
+ "trackedObject_other": "{{count}} objects",
+ "noObjectDetailData": "No object detail data available.",
+ "settings": "Detail View Settings",
+ "alwaysExpandActive": {
+ "title": "Always expand active",
+ "desc": "Always expand the active review item's object details when available."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Tracked point",
+ "clickToSeek": "Click to seek to this time"
+ },
"documentTitle": "Review - Frigate",
"recordings": {
"documentTitle": "Recordings - Frigate"
@@ -33,6 +56,10 @@
},
"selected_one": "{{count}} selected",
"selected_other": "{{count}} selected",
+ "select_all": "All",
"camera": "Camera",
- "detected": "detected"
+ "detected": "detected",
+ "normalActivity": "Normal",
+ "needsReview": "Needs review",
+ "securityConcern": "Security concern"
}
diff --git a/web/public/locales/en/views/explore.json b/web/public/locales/en/views/explore.json
index 7e2381445..53b04e6c4 100644
--- a/web/public/locales/en/views/explore.json
+++ b/web/public/locales/en/views/explore.json
@@ -24,8 +24,7 @@
"textTokenizer": "Text tokenizer"
},
"tips": {
- "context": "You may want to reindex the embeddings of your tracked objects once the models are downloaded.",
- "documentation": "Read the documentation"
+ "context": "You may want to reindex the embeddings of your tracked objects once the models are downloaded."
},
"error": "An error has occurred. Check Frigate logs."
}
@@ -34,15 +33,16 @@
"type": {
"details": "details",
"snapshot": "snapshot",
+ "thumbnail": "thumbnail",
"video": "video",
- "object_lifecycle": "object lifecycle"
+ "tracking_details": "tracking details"
},
- "objectLifecycle": {
- "title": "Object Lifecycle",
+ "trackingDetails": {
+ "title": "Tracking Details",
"noImageFound": "No image found for this timestamp.",
"createObjectMask": "Create Object Mask",
"adjustAnnotationSettings": "Adjust annotation settings",
- "scrollViewTips": "Scroll to view the significant moments of this object's lifecycle.",
+ "scrollViewTips": "Click to view the significant moments of this object's lifecycle.",
"autoTrackingTips": "Bounding box positions will be inaccurate for autotracking cameras.",
"count": "{{first}} of {{second}}",
"trackedPoint": "Tracked Point",
@@ -61,7 +61,8 @@
"header": {
"zones": "Zones",
"ratio": "Ratio",
- "area": "Area"
+ "area": "Area",
+ "score": "Score"
}
},
"annotationSettings": {
@@ -72,12 +73,11 @@
},
"offset": {
"label": "Annotation Offset",
- "desc": "This data comes from your camera's detect feed but is overlayed on images from the the record feed. It is unlikely that the two streams are perfectly in sync. As a result, the bounding box and the footage will not line up perfectly. However, the annotation_offset field can be used to adjust this.",
- "documentation": "Read the documentation ",
+ "desc": "This data comes from your camera's detect feed but is overlayed on images from the the record feed. It is unlikely that the two streams are perfectly in sync. As a result, the bounding box and the footage will not line up perfectly. You can use this setting to offset the annotations forward or backward in time to better align them with the recorded footage.",
"millisecondsToOffset": "Milliseconds to offset detect annotations by. Default: 0",
- "tips": "TIP: Imagine there is an event clip with a person walking from left to right. If the event timeline bounding box is consistently to the left of the person then the value should be decreased. Similarly, if a person is walking from left to right and the bounding box is consistently ahead of the person then the value should be increased.",
+ "tips": "Lower the value if the video playback is ahead of the boxes and path points, and increase the value if the video playback is behind them. This value can be negative.",
"toast": {
- "success": "Annotation offset for {{camera}} has been saved to the config file. Restart Frigate to apply your changes."
+ "success": "Annotation offset for {{camera}} has been saved to the config file."
}
}
},
@@ -103,12 +103,16 @@
"success": {
"regenerate": "A new description has been requested from {{provider}}. Depending on the speed of your provider, the new description may take some time to regenerate.",
"updatedSublabel": "Successfully updated sub label.",
- "updatedLPR": "Successfully updated license plate."
+ "updatedLPR": "Successfully updated license plate.",
+ "updatedAttributes": "Successfully updated attributes.",
+ "audioTranscription": "Successfully requested audio transcription. Depending on the speed of your Frigate server, the transcription may take some time to complete."
},
"error": {
"regenerate": "Failed to call {{provider}} for a new description: {{errorMessage}}",
"updatedSublabelFailed": "Failed to update sub label: {{errorMessage}}",
- "updatedLPRFailed": "Failed to update license plate: {{errorMessage}}"
+ "updatedLPRFailed": "Failed to update license plate: {{errorMessage}}",
+ "updatedAttributesFailed": "Failed to update attributes: {{errorMessage}}",
+ "audioTranscription": "Failed to request audio transcription: {{errorMessage}}"
}
}
},
@@ -123,6 +127,10 @@
"desc": "Enter a new license plate value for this {{label}}",
"descNoLabel": "Enter a new license plate value for this tracked object"
},
+ "editAttributes": {
+ "title": "Edit attributes",
+ "desc": "Select classification attributes for this {{label}}"
+ },
"snapshotScore": {
"label": "Snapshot Score"
},
@@ -130,7 +138,11 @@
"label": "Top Score",
"info": "The top score is the highest median score for the tracked object, so this may differ from the score shown on the search result thumbnail."
},
+ "score": {
+ "label": "Score"
+ },
"recognizedLicensePlate": "Recognized License Plate",
+ "attributes": "Classification Attributes",
"estimatedSpeed": "Estimated Speed",
"objects": "Objects",
"camera": "Camera",
@@ -154,6 +166,9 @@
"tips": {
"descriptionSaved": "Successfully saved description",
"saveDescriptionFailed": "Failed to update the description: {{errorMessage}}"
+ },
+ "title": {
+ "label": "Title"
}
},
"itemMenu": {
@@ -165,14 +180,26 @@
"label": "Download snapshot",
"aria": "Download snapshot"
},
- "viewObjectLifecycle": {
- "label": "View object lifecycle",
- "aria": "Show the object lifecycle"
+ "downloadCleanSnapshot": {
+ "label": "Download clean snapshot",
+ "aria": "Download clean snapshot"
+ },
+ "viewTrackingDetails": {
+ "label": "View tracking details",
+ "aria": "Show the tracking details"
},
"findSimilar": {
"label": "Find similar",
"aria": "Find similar tracked objects"
},
+ "addTrigger": {
+ "label": "Add trigger",
+ "aria": "Add a trigger for this tracked object"
+ },
+ "audioTranscription": {
+ "label": "Transcribe",
+ "aria": "Request audio transcription"
+ },
"submitToPlus": {
"label": "Submit to Frigate+",
"aria": "Submit to Frigate Plus"
@@ -183,12 +210,18 @@
},
"deleteTrackedObject": {
"label": "Delete this tracked object"
+ },
+ "showObjectDetails": {
+ "label": "Show object path"
+ },
+ "hideObjectDetails": {
+ "label": "Hide object path"
}
},
"dialog": {
"confirmDelete": {
"title": "Confirm Delete",
- "desc": "Deleting this tracked object removes the snapshot, any saved embeddings, and any associated object lifecycle entries. Recorded footage of this tracked object in History view will NOT be deleted.mode: {{effectiveRetainMode}}, so this on-demand recording will only keep segments with {{effectiveRetainModeName}}."
+ }
},
"editLayout": {
"label": "Edit Layout",
@@ -154,5 +173,24 @@
"label": "Edit Camera Group"
},
"exitEdit": "Exit Editing"
+ },
+ "noCameras": {
+ "title": "No Cameras Configured",
+ "description": "Get started by connecting a camera to Frigate.",
+ "buttonText": "Add Camera",
+ "restricted": {
+ "title": "No Cameras Available",
+ "description": "You don't have permission to view any cameras in this group."
+ },
+ "default": {
+ "title": "No Cameras Configured",
+ "description": "Get started by connecting a camera to Frigate.",
+ "buttonText": "Add Camera"
+ },
+ "group": {
+ "title": "No Cameras in Group",
+ "description": "This camera group has no assigned or enabled cameras.",
+ "buttonText": "Manage Groups"
+ }
}
}
diff --git a/web/public/locales/en/views/search.json b/web/public/locales/en/views/search.json
index 22da7721f..dae622c70 100644
--- a/web/public/locales/en/views/search.json
+++ b/web/public/locales/en/views/search.json
@@ -16,6 +16,7 @@
"labels": "Labels",
"zones": "Zones",
"sub_labels": "Sub Labels",
+ "attributes": "Attributes",
"search_type": "Search Type",
"time_range": "Time Range",
"before": "Before",
diff --git a/web/public/locales/en/views/settings.json b/web/public/locales/en/views/settings.json
index 2b92e81cd..ea2869986 100644
--- a/web/public/locales/en/views/settings.json
+++ b/web/public/locales/en/views/settings.json
@@ -2,23 +2,27 @@
"documentTitle": {
"default": "Settings - Frigate",
"authentication": "Authentication Settings - Frigate",
- "camera": "Camera Settings - Frigate",
+ "cameraManagement": "Manage Cameras - Frigate",
+ "cameraReview": "Camera Review Settings - Frigate",
"enrichments": "Enrichments Settings - Frigate",
"masksAndZones": "Mask and Zone Editor - Frigate",
"motionTuner": "Motion Tuner - Frigate",
"object": "Debug - Frigate",
- "general": "General Settings - Frigate",
+ "general": "UI Settings - Frigate",
"frigatePlus": "Frigate+ Settings - Frigate",
"notifications": "Notification Settings - Frigate"
},
"menu": {
"ui": "UI",
"enrichments": "Enrichments",
- "cameras": "Camera Settings",
+ "cameraManagement": "Management",
+ "cameraReview": "Review",
"masksAndZones": "Masks / Zones",
"motionTuner": "Motion Tuner",
+ "triggers": "Triggers",
"debug": "Debug",
"users": "Users",
+ "roles": "Roles",
"notifications": "Notifications",
"frigateplus": "Frigate+"
},
@@ -33,7 +37,7 @@
"noCamera": "No Camera"
},
"general": {
- "title": "General Settings",
+ "title": "UI Settings",
"liveDashboard": {
"title": "Live Dashboard",
"automaticLiveView": {
@@ -43,6 +47,14 @@
"playAlertVideos": {
"label": "Play Alert Videos",
"desc": "By default, recent alerts on the Live dashboard play as small looping videos. Disable this option to only show a static image of recent alerts on this device/browser."
+ },
+ "displayCameraNames": {
+ "label": "Always Show Camera Names",
+ "desc": "Always show the camera names in a chip in the multi-camera live view dashboard."
+ },
+ "liveFallbackTimeout": {
+ "label": "Live Player Fallback Timeout",
+ "desc": "When a camera's high quality live stream is unavailable, fall back to low bandwidth mode after this many seconds. Default: 3."
}
},
"storedLayouts": {
@@ -92,7 +104,6 @@
"semanticSearch": {
"title": "Semantic Search",
"desc": "Semantic Search in Frigate allows you to find tracked objects within your review items using either the image itself, a user-defined text description, or an automatically generated one.",
- "readTheDocumentation": "Read the Documentation",
"reindexNow": {
"label": "Reindex Now",
"desc": "Reindexing will regenerate embeddings for all tracked object. This process runs in the background and may max out your CPU and take a fair amount of time depending on the number of tracked objects you have.",
@@ -119,7 +130,6 @@
"faceRecognition": {
"title": "Face Recognition",
"desc": "Face recognition allows people to be assigned names and when their face is recognized Frigate will assign the person's name as a sub label. This information is included in the UI, filters, as well as in notifications.",
- "readTheDocumentation": "Read the Documentation",
"modelSize": {
"label": "Model Size",
"desc": "The size of the model used for face recognition.",
@@ -135,8 +145,7 @@
},
"licensePlateRecognition": {
"title": "License Plate Recognition",
- "desc": "Frigate can recognize license plates on vehicles and automatically add the detected characters to the recognized_license_plate field or a known name as a sub_label to objects that are of type car. A common use case may be to read the license plates of cars pulling into a driveway or cars passing by on a street.",
- "readTheDocumentation": "Read the Documentation"
+ "desc": "Frigate can recognize license plates on vehicles and automatically add the detected characters to the recognized_license_plate field or a known name as a sub_label to objects that are of type car. A common use case may be to read the license plates of cars pulling into a driveway or cars passing by on a street."
},
"restart_required": "Restart required (Enrichments settings changed)",
"toast": {
@@ -144,12 +153,245 @@
"error": "Failed to save config changes: {{errorMessage}}"
}
},
- "camera": {
- "title": "Camera Settings",
+ "cameraWizard": {
+ "title": "Add Camera",
+ "description": "Follow the steps below to add a new camera to your Frigate installation.",
+ "steps": {
+ "nameAndConnection": "Name & Connection",
+ "probeOrSnapshot": "Probe or Snapshot",
+ "streamConfiguration": "Stream Configuration",
+ "validationAndTesting": "Validation & Testing"
+ },
+ "save": {
+ "success": "Successfully saved new camera {{cameraName}}.",
+ "failure": "Error saving {{cameraName}}."
+ },
+ "testResultLabels": {
+ "resolution": "Resolution",
+ "video": "Video",
+ "audio": "Audio",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Please provide a valid stream URL",
+ "testFailed": "Stream test failed: {{error}}"
+ },
+ "step1": {
+ "description": "Enter your camera details and choose to probe the camera or manually select the brand.",
+ "cameraName": "Camera Name",
+ "cameraNamePlaceholder": "e.g., front_door or Back Yard Overview",
+ "host": "Host/IP Address",
+ "port": "Port",
+ "username": "Username",
+ "usernamePlaceholder": "Optional",
+ "password": "Password",
+ "passwordPlaceholder": "Optional",
+ "selectTransport": "Select transport protocol",
+ "cameraBrand": "Camera Brand",
+ "selectBrand": "Select camera brand for URL template",
+ "customUrl": "Custom Stream URL",
+ "brandInformation": "Brand information",
+ "brandUrlFormat": "For cameras with the RTSP URL format as: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "connectionSettings": "Connection Settings",
+ "detectionMethod": "Stream Detection Method",
+ "onvifPort": "ONVIF Port",
+ "probeMode": "Probe camera",
+ "manualMode": "Manual selection",
+ "detectionMethodDescription": "Probe the camera with ONVIF (if supported) to find camera stream URLs, or manually select the camera brand to use pre-defined URLs. To enter a custom RTSP URL, choose the manual method and select \"Other\".",
+ "onvifPortDescription": "For cameras that support ONVIF, this is usually 80 or 8080.",
+ "useDigestAuth": "Use digest authentication",
+ "useDigestAuthDescription": "Use HTTP digest authentication for ONVIF. Some cameras may require a dedicated ONVIF username/password instead of the standard admin user.",
+ "errors": {
+ "brandOrCustomUrlRequired": "Either select a camera brand with host/IP or choose 'Other' with a custom URL",
+ "nameRequired": "Camera name is required",
+ "nameLength": "Camera name must be 64 characters or less",
+ "invalidCharacters": "Camera name contains invalid characters",
+ "nameExists": "Camera name already exists",
+ "customUrlRtspRequired": "Custom URLs must begin with \"rtsp://\". Manual configuration is required for non-RTSP camera streams."
+ }
+ },
+ "step2": {
+ "description": "Probe the camera for available streams or configure manual settings based on your selected detection method.",
+ "testSuccess": "Connection test successful!",
+ "testFailed": "Connection test failed. Please check your input and try again.",
+ "testFailedTitle": "Test Failed",
+ "streamDetails": "Stream Details",
+ "probing": "Probing camera...",
+ "retry": "Retry",
+ "testing": {
+ "probingMetadata": "Probing camera metadata...",
+ "fetchingSnapshot": "Fetching camera snapshot..."
+ },
+ "probeFailed": "Failed to probe camera: {{error}}",
+ "probingDevice": "Probing device...",
+ "probeSuccessful": "Probe successful",
+ "probeError": "Probe Error",
+ "probeNoSuccess": "Probe unsuccessful",
+ "deviceInfo": "Device Information",
+ "manufacturer": "Manufacturer",
+ "model": "Model",
+ "firmware": "Firmware",
+ "profiles": "Profiles",
+ "ptzSupport": "PTZ Support",
+ "autotrackingSupport": "Autotracking Support",
+ "presets": "Presets",
+ "rtspCandidates": "RTSP Candidates",
+ "rtspCandidatesDescription": "The following RTSP URLs were found from the camera probe. Test the connection to view stream metadata.",
+ "noRtspCandidates": "No RTSP URLs were found from the camera. Your credentials may be incorrect, or the camera may not support ONVIF or the method used to retrieve RTSP URLs. Go back and enter the RTSP URL manually.",
+ "candidateStreamTitle": "Candidate {{number}}",
+ "useCandidate": "Use",
+ "uriCopy": "Copy",
+ "uriCopied": "URI copied to clipboard",
+ "testConnection": "Test Connection",
+ "toggleUriView": "Click to toggle full URI view",
+ "connected": "Connected",
+ "notConnected": "Not Connected",
+ "errors": {
+ "hostRequired": "Host/IP address is required"
+ }
+ },
+ "step3": {
+ "description": "Configure stream roles and add additional streams for your camera.",
+ "streamsTitle": "Camera Streams",
+ "addStream": "Add Stream",
+ "addAnotherStream": "Add Another Stream",
+ "streamTitle": "Stream {{number}}",
+ "streamUrl": "Stream URL",
+ "streamUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "selectStream": "Select a stream",
+ "searchCandidates": "Search candidates...",
+ "noStreamFound": "No stream found",
+ "url": "URL",
+ "resolution": "Resolution",
+ "selectResolution": "Select resolution",
+ "quality": "Quality",
+ "selectQuality": "Select quality",
+ "roles": "Roles",
+ "roleLabels": {
+ "detect": "Object Detection",
+ "record": "Recording",
+ "audio": "Audio"
+ },
+ "testStream": "Test Connection",
+ "testSuccess": "Stream test successful!",
+ "testFailed": "Stream test failed",
+ "testFailedTitle": "Test Failed",
+ "connected": "Connected",
+ "notConnected": "Not Connected",
+ "featuresTitle": "Features",
+ "go2rtc": "Reduce connections to camera",
+ "detectRoleWarning": "At least one stream must have the \"detect\" role to proceed.",
+ "rolesPopover": {
+ "title": "Stream Roles",
+ "detect": "Main feed for object detection.",
+ "record": "Saves segments of the video feed based on configuration settings.",
+ "audio": "Feed for audio based detection."
+ },
+ "featuresPopover": {
+ "title": "Stream Features",
+ "description": "Use go2rtc restreaming to reduce connections to your camera."
+ }
+ },
+ "step4": {
+ "description": "Final validation and analysis before saving your new camera. Connect each stream before saving.",
+ "validationTitle": "Stream Validation",
+ "connectAllStreams": "Connect All Streams",
+ "reconnectionSuccess": "Reconnection successful.",
+ "reconnectionPartial": "Some streams failed to reconnect.",
+ "streamUnavailable": "Stream preview unavailable",
+ "reload": "Reload",
+ "connecting": "Connecting...",
+ "streamTitle": "Stream {{number}}",
+ "valid": "Valid",
+ "failed": "Failed",
+ "notTested": "Not tested",
+ "connectStream": "Connect",
+ "connectingStream": "Connecting",
+ "disconnectStream": "Disconnect",
+ "estimatedBandwidth": "Estimated Bandwidth",
+ "roles": "Roles",
+ "ffmpegModule": "Use stream compatibility mode",
+ "ffmpegModuleDescription": "If the stream does not load after several attempts, try enabling this. When enabled, Frigate will use the ffmpeg module with go2rtc. This may provide better compatibility with some camera streams.",
+ "none": "None",
+ "error": "Error",
+ "streamValidated": "Stream {{number}} validated successfully",
+ "streamValidationFailed": "Stream {{number}} validation failed",
+ "saveAndApply": "Save New Camera",
+ "saveError": "Invalid configuration. Please check your settings.",
+ "issues": {
+ "title": "Stream Validation",
+ "videoCodecGood": "Video codec is {{codec}}.",
+ "audioCodecGood": "Audio codec is {{codec}}.",
+ "resolutionHigh": "A resolution of {{resolution}} may cause increased resource usage.",
+ "resolutionLow": "A resolution of {{resolution}} may be too low for reliable detection of small objects.",
+ "noAudioWarning": "No audio detected for this stream, recordings will not have audio.",
+ "audioCodecRecordError": "The AAC audio codec is required to support audio in recordings.",
+ "audioCodecRequired": "An audio stream is required to support audio detection.",
+ "restreamingWarning": "Reducing connections to the camera for the record stream may increase CPU usage slightly.",
+ "brands": {
+ "reolink-rtsp": "Reolink RTSP is not recommended. Enable HTTP in the camera's firmware settings and restart the wizard.",
+ "reolink-http": "Reolink HTTP streams should use FFmpeg for better compatibility. Enable 'Use stream compatibility mode' for this stream."
+ },
+ "dahua": {
+ "substreamWarning": "Substream 1 is locked to a low resolution. Many Dahua / Amcrest / EmpireTech cameras support additional substreams that need to be enabled in the camera's settings. It is recommended to check and utilize those streams if available."
+ },
+ "hikvision": {
+ "substreamWarning": "Substream 1 is locked to a low resolution. Many Hikvision cameras support additional substreams that need to be enabled in the camera's settings. It is recommended to check and utilize those streams if available."
+ }
+ }
+ }
+ },
+ "cameraManagement": {
+ "title": "Manage Cameras",
+ "addCamera": "Add New Camera",
+ "editCamera": "Edit Camera:",
+ "selectCamera": "Select a Camera",
+ "backToSettings": "Back to Camera Settings",
"streams": {
- "title": "Streams",
+ "title": "Enable / Disable Cameras",
"desc": "Temporarily disable a camera until Frigate restarts. Disabling a camera completely stops Frigate's processing of this camera's streams. Detection, recording, and debugging will be unavailable.Region Boxes
Bright green boxes will be overlaid on areas of interest in the frame that are being sent to the object detector.
" }, + "paths": { + "title": "Paths", + "desc": "Show significant points of the tracked object's path", + "tips": "Paths
Lines and circles will indicate significant points the tracked object has moved during its lifecycle.
" + }, "objectShapeFilterDrawing": { "title": "Object Shape Filter Drawing", "desc": "Draw a rectangle on the image to view area and ratio details", "tips": "Enable this option to draw a rectangle on the camera image to show its area and ratio. These values can then be used to set object shape filter parameters in your config.", - "document": "Read the documentation ", "score": "Score", "ratio": "Ratio", "area": "Area" @@ -427,7 +684,7 @@ "desc": "Manage this Frigate instance's user accounts." }, "addUser": "Add User", - "updatePassword": "Update Password", + "updatePassword": "Reset Password", "toast": { "success": { "createUser": "User {{user}} created successfully", @@ -448,7 +705,7 @@ "role": "Role", "noUsers": "No users found.", "changeRole": "Change user role", - "password": "Password", + "password": "Reset Password", "deleteUser": "Delete user" }, "dialog": { @@ -461,6 +718,8 @@ "password": { "title": "Password", "placeholder": "Enter password", + "show": "Show password", + "hide": "Hide password", "confirm": { "title": "Confirm Password", "placeholder": "Confirm Password" @@ -472,6 +731,10 @@ "strong": "Strong", "veryStrong": "Very Strong" }, + "requirements": { + "title": "Password requirements:", + "length": "At least 12 characters" + }, "match": "Passwords match", "notMatch": "Passwords don't match" }, @@ -482,6 +745,10 @@ "placeholder": "Re-enter new password" } }, + "currentPassword": { + "title": "Current Password", + "placeholder": "Enter your current password" + }, "usernameIsRequired": "Username is required", "passwordIsRequired": "Password is required" }, @@ -499,9 +766,14 @@ "passwordSetting": { "cannotBeEmpty": "Password cannot be empty", "doNotMatch": "Passwords do not match", + "currentPasswordRequired": "Current password is required", + "incorrectCurrentPassword": "Current password is incorrect", + "passwordVerificationFailed": "Failed to verify password", "updatePassword": "Update Password for {{username}}", "setPassword": "Set Password", - "desc": "Create a strong password to secure this account." + "desc": "Create a strong password to secure this account.", + "multiDeviceWarning": "Any other devices where you are logged in will be required to re-login within {{refresh_time}}.", + "multiDeviceAdmin": "You can also force all users to re-authenticate immediately by rotating your JWT secret." }, "changeRole": { "title": "Change User Role", @@ -512,7 +784,69 @@ "admin": "Admin", "adminDesc": "Full access to all features.", "viewer": "Viewer", - "viewerDesc": "Limited to Live dashboards, Review, Explore, and Exports only." + "viewerDesc": "Limited to Live dashboards, Review, Explore, and Exports only.", + "customDesc": "Custom role with specific camera access." + } + } + } + }, + "roles": { + "management": { + "title": "Viewer Role Management", + "desc": "Manage custom viewer roles and their camera access permissions for this Frigate instance." + }, + "addRole": "Add Role", + "table": { + "role": "Role", + "cameras": "Cameras", + "actions": "Actions", + "noRoles": "No custom roles found.", + "editCameras": "Edit Cameras", + "deleteRole": "Delete Role" + }, + "toast": { + "success": { + "createRole": "Role {{role}} created successfully", + "updateCameras": "Cameras updated for role {{role}}", + "deleteRole": "Role {{role}} deleted successfully", + "userRolesUpdated_one": "{{count}} user assigned to this role has been updated to 'viewer', which has access to all cameras.", + "userRolesUpdated_other": "{{count}} users assigned to this role have been updated to 'viewer', which has access to all cameras." + }, + "error": { + "createRoleFailed": "Failed to create role: {{errorMessage}}", + "updateCamerasFailed": "Failed to update cameras: {{errorMessage}}", + "deleteRoleFailed": "Failed to delete role: {{errorMessage}}", + "userUpdateFailed": "Failed to update user roles: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Create New Role", + "desc": "Add a new role and specify camera access permissions." + }, + "editCameras": { + "title": "Edit Role Cameras", + "desc": "Update camera access for the role {{role}}." + }, + "deleteRole": { + "title": "Delete Role", + "desc": "This action cannot be undone. This will permanently delete the role and assign any users with this role to the 'viewer' role, which will give viewer access to all cameras.", + "warn": "Are you sure you want to delete {{role}}?", + "deleting": "Deleting..." + }, + "form": { + "role": { + "title": "Role Name", + "placeholder": "Enter role name", + "desc": "Only letters, numbers, periods and underscores allowed.", + "roleIsRequired": "Role name is required", + "roleOnlyInclude": "Role name may only include letters, numbers, . or _", + "roleExists": "A role with this name already exists." + }, + "cameras": { + "title": "Cameras", + "desc": "Select cameras this role has access to. At least one camera is required.", + "required": "At least one camera must be selected." } } } @@ -521,13 +855,11 @@ "title": "Notifications", "notificationSettings": { "title": "Notification Settings", - "desc": "Frigate can natively send push notifications to your device when it is running in the browser or installed as a PWA.", - "documentation": "Read the Documentation" + "desc": "Frigate can natively send push notifications to your device when it is running in the browser or installed as a PWA." }, "notificationUnavailable": { "title": "Notifications Unavailable", - "desc": "Web push notifications require a secure context (https://…). This is a browser limitation. Access Frigate securely to use notifications.",
- "documentation": "Read the Documentation"
+ "desc": "Web push notifications require a secure context (https://…). This is a browser limitation. Access Frigate securely to use notifications."
},
"globalSettings": {
"title": "Global Settings",
@@ -584,7 +916,6 @@
"snapshotConfig": {
"title": "Snapshot Configuration",
"desc": "Submitting to Frigate+ requires both snapshots and clean_copy snapshots to be enabled in your config.",
- "documentation": "Read the documentation",
"cleanCopyWarning": "Some cameras have snapshots enabled but have the clean copy disabled. You need to enable clean_copy in your snapshot config to be able to submit images from these cameras to Frigate+.",
"table": {
"camera": "Camera",
@@ -615,5 +946,126 @@
"success": "Frigate+ settings have been saved. Restart Frigate to apply changes.",
"error": "Failed to save config changes: {{errorMessage}}"
}
+ },
+ "triggers": {
+ "documentTitle": "Triggers",
+ "semanticSearch": {
+ "title": "Semantic Search is disabled",
+ "desc": "Semantic Search must be enabled to use Triggers."
+ },
+ "management": {
+ "title": "Triggers",
+ "desc": "Manage triggers for {{camera}}. Use the thumbnail type to trigger on similar thumbnails to your selected tracked object, and the description type to trigger on similar descriptions to text you specify."
+ },
+ "addTrigger": "Add Trigger",
+ "table": {
+ "name": "Name",
+ "type": "Type",
+ "content": "Content",
+ "threshold": "Threshold",
+ "actions": "Actions",
+ "noTriggers": "No triggers configured for this camera.",
+ "edit": "Edit",
+ "deleteTrigger": "Delete Trigger",
+ "lastTriggered": "Last triggered"
+ },
+ "type": {
+ "thumbnail": "Thumbnail",
+ "description": "Description"
+ },
+ "actions": {
+ "notification": "Send Notification",
+ "sub_label": "Add Sub Label",
+ "attribute": "Add Attribute"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "Create Trigger",
+ "desc": "Create a trigger for camera {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Edit Trigger",
+ "desc": "Edit the settings for trigger on camera {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Delete Trigger",
+ "desc": "Are you sure you want to delete the trigger {{triggerName}}? This action cannot be undone."
+ },
+ "form": {
+ "name": {
+ "title": "Name",
+ "placeholder": "Name this trigger",
+ "description": "Enter a unique name or description to identify this trigger",
+ "error": {
+ "minLength": "Field must be at least 2 characters long.",
+ "invalidCharacters": "Field can only contain letters, numbers, underscores, and hyphens.",
+ "alreadyExists": "A trigger with this name already exists for this camera."
+ }
+ },
+ "enabled": {
+ "description": "Enable or disable this trigger"
+ },
+ "type": {
+ "title": "Type",
+ "placeholder": "Select trigger type",
+ "description": "Trigger when a similar tracked object description is detected",
+ "thumbnail": "Trigger when a similar tracked object thumbnail is detected"
+ },
+ "content": {
+ "title": "Content",
+ "imagePlaceholder": "Select a thumbnail",
+ "textPlaceholder": "Enter text content",
+ "imageDesc": "Only the most recent 100 thumbnails are displayed. If you can't find your desired thumbnail, please review earlier objects in Explore and set up a trigger from the menu there.",
+ "textDesc": "Enter text to trigger this action when a similar tracked object description is detected.",
+ "error": {
+ "required": "Content is required."
+ }
+ },
+ "threshold": {
+ "title": "Threshold",
+ "desc": "Set the similarity threshold for this trigger. A higher threshold means a closer match is required to fire the trigger.",
+ "error": {
+ "min": "Threshold must be at least 0",
+ "max": "Threshold must be at most 1"
+ }
+ },
+ "actions": {
+ "title": "Actions",
+ "desc": "By default, Frigate fires an MQTT message for all triggers. Sub labels add the trigger name to the object label. Attributes are searchable metadata stored separately in the tracked object metadata.",
+ "error": {
+ "min": "At least one action must be selected."
+ }
+ }
+ }
+ },
+ "wizard": {
+ "title": "Create Trigger",
+ "step1": {
+ "description": "Configure the basic settings for your trigger."
+ },
+ "step2": {
+ "description": "Set up the content that will trigger this action."
+ },
+ "step3": {
+ "description": "Configure the threshold and actions for this trigger."
+ },
+ "steps": {
+ "nameAndType": "Name and Type",
+ "configureData": "Configure Data",
+ "thresholdAndActions": "Threshold and Actions"
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Trigger {{name}} created successfully.",
+ "updateTrigger": "Trigger {{name}} updated successfully.",
+ "deleteTrigger": "Trigger {{name}} deleted successfully."
+ },
+ "error": {
+ "createTriggerFailed": "Failed to create trigger: {{errorMessage}}",
+ "updateTriggerFailed": "Failed to update trigger: {{errorMessage}}",
+ "deleteTriggerFailed": "Failed to delete trigger: {{errorMessage}}"
+ }
+ }
}
}
diff --git a/web/public/locales/en/views/system.json b/web/public/locales/en/views/system.json
index 059f05f9f..da774e302 100644
--- a/web/public/locales/en/views/system.json
+++ b/web/public/locales/en/views/system.json
@@ -42,6 +42,7 @@
"inferenceSpeed": "Detector Inference Speed",
"temperature": "Detector Temperature",
"cpuUsage": "Detector CPU Usage",
+ "cpuUsageInformation": "CPU used in preparing input and output data to/from detection models. This value does not measure inference usage, even if using a GPU or accelerator.",
"memoryUsage": "Detector Memory Usage"
},
"hardwareInfo": {
@@ -75,12 +76,24 @@
}
},
"npuUsage": "NPU Usage",
- "npuMemory": "NPU Memory"
+ "npuMemory": "NPU Memory",
+ "intelGpuWarning": {
+ "title": "Intel GPU Stats Warning",
+ "message": "GPU stats unavailable",
+ "description": "This is a known bug in Intel's GPU stats reporting tools (intel_gpu_top) where it will break and repeatedly return a GPU usage of 0% even in cases where hardware acceleration and object detection are correctly running on the (i)GPU. This is not a Frigate bug. You can restart the host to temporarily fix the issue and confirm that the GPU is working correctly. This does not affect performance."
+ }
},
"otherProcesses": {
"title": "Other Processes",
"processCpuUsage": "Process CPU Usage",
- "processMemoryUsage": "Process Memory Usage"
+ "processMemoryUsage": "Process Memory Usage",
+ "series": {
+ "go2rtc": "go2rtc",
+ "recording": "recording",
+ "review_segment": "review segment",
+ "embeddings": "embeddings",
+ "audio_detector": "audio detector"
+ }
}
},
"storage": {
@@ -91,6 +104,10 @@
"tips": "This value represents the total storage used by the recordings in Frigate's database. Frigate does not track storage usage for all files on your disk.",
"earliestRecording": "Earliest recording available:"
},
+ "shm": {
+ "title": "SHM (shared memory) allocation",
+ "warning": "The current SHM size of {{total}}MB is too small. Increase it to at least {{min_shm}}MB."
+ },
"cameraStorage": {
"title": "Camera Storage",
"camera": "Camera",
@@ -158,11 +175,13 @@
"reindexingEmbeddings": "Reindexing embeddings ({{processed}}% complete)",
"cameraIsOffline": "{{camera}} is offline",
"detectIsSlow": "{{detect}} is slow ({{speed}} ms)",
- "detectIsVerySlow": "{{detect}} is very slow ({{speed}} ms)"
+ "detectIsVerySlow": "{{detect}} is very slow ({{speed}} ms)",
+ "shmTooLow": "/dev/shm allocation ({{total}} MB) should be increased to at least {{min}} MB."
},
"enrichments": {
"title": "Enrichments",
"infPerSecond": "Inferences Per Second",
+ "averageInf": "Average Inference Time",
"embeddings": {
"image_embedding": "Image Embedding",
"text_embedding": "Text Embedding",
@@ -174,7 +193,16 @@
"plate_recognition_speed": "Plate Recognition Speed",
"text_embedding_speed": "Text Embedding Speed",
"yolov9_plate_detection_speed": "YOLOv9 Plate Detection Speed",
- "yolov9_plate_detection": "YOLOv9 Plate Detection"
+ "yolov9_plate_detection": "YOLOv9 Plate Detection",
+ "review_description": "Review Description",
+ "review_description_speed": "Review Description Speed",
+ "review_description_events_per_second": "Review Description",
+ "object_description": "Object Description",
+ "object_description_speed": "Object Description Speed",
+ "object_description_events_per_second": "Object Description",
+ "classification": "{{name}} Classification",
+ "classification_speed": "{{name}} Classification Speed",
+ "classification_events_per_second": "{{name}} Classification Events Per Second"
}
}
}
diff --git a/web/public/locales/es/audio.json b/web/public/locales/es/audio.json
index 16288b261..2641cb561 100644
--- a/web/public/locales/es/audio.json
+++ b/web/public/locales/es/audio.json
@@ -31,7 +31,7 @@
"crying": "Llanto",
"synthetic_singing": "Canto sintético",
"rapping": "Rap",
- "humming": "Tarareo",
+ "humming": "Zumbido leve",
"groan": "Gemido",
"grunt": "Gruñido",
"whistling": "Silbido",
@@ -129,7 +129,7 @@
"sitar": "Sitar",
"mandolin": "Mandolina",
"zither": "Cítara",
- "ukulele": "Ukulele",
+ "ukulele": "Ukelele",
"piano": "Piano",
"organ": "Órgano",
"electronic_organ": "Órgano electrónico",
@@ -153,7 +153,7 @@
"mallet_percussion": "Percusión con mazas",
"marimba": "Marimba",
"glockenspiel": "Glockenspiel",
- "steelpan": "Steelpan",
+ "steelpan": "SarténAcero",
"orchestra": "Orquesta",
"trumpet": "Trompeta",
"string_section": "Sección de cuerdas",
@@ -183,13 +183,13 @@
"psychedelic_rock": "Rock psicodélico",
"rhythm_and_blues": "Rhythm and blues",
"soul_music": "Música soul",
- "country": "Country",
+ "country": "País",
"swing_music": "Música swing",
"disco": "Disco",
"house_music": "Música House",
"dubstep": "Dubstep",
"drum_and_bass": "Drum and Bass",
- "electronica": "Electronica",
+ "electronica": "Electrónica",
"electronic_dance_music": "Música Dance Electronica",
"music_of_latin_america": "Música de América Latina",
"salsa_music": "Música Salsa",
@@ -207,7 +207,7 @@
"song": "Canción",
"background_music": "Música Background",
"soundtrack_music": "Música de Pelicula",
- "lullaby": "Lullaby",
+ "lullaby": "Cancion de cuna",
"video_game_music": "Música de Videojuego",
"christmas_music": "Música Navideña",
"sad_music": "Música triste",
@@ -425,5 +425,79 @@
"radio": "Radio",
"gunshot": "Disparo",
"fusillade": "Descarga de Fusilería",
- "pink_noise": "Ruido Rosa"
+ "pink_noise": "Ruido Rosa",
+ "shofar": "Shofar",
+ "liquid": "Líquido",
+ "splash": "Chapoteo",
+ "slosh": "líquido_en_movimiento",
+ "squish": "Chapotear",
+ "drip": "Goteo",
+ "pour": "Derramar",
+ "trickle": "Chorrito",
+ "gush": "Chorro",
+ "fill": "Llenar",
+ "spray": "Pulverizar",
+ "pump": "Bombear",
+ "stir": "Remover",
+ "boiling": "Hirviendo",
+ "sonar": "Sonar",
+ "arrow": "Flecha",
+ "whoosh": "Zas",
+ "thump": "Golpear",
+ "thunk": "Golpe_sordo",
+ "electronic_tuner": "Afinador_electrónico",
+ "effects_unit": "Unidades de efecto",
+ "chorus_effect": "Efecto Coral",
+ "basketball_bounce": "Bote baloncesto",
+ "bang": "Bang",
+ "slap": "Bofeteada",
+ "whack": "Aporreo",
+ "smash": "Aplastar",
+ "breaking": "Romper",
+ "bouncing": "Botar",
+ "whip": "Latigazo",
+ "flap": "Aleteo",
+ "scratch": "Arañazo",
+ "scrape": "Arañar",
+ "rub": "Frotar",
+ "roll": "Roll",
+ "crushing": "aplastar",
+ "crumpling": "Arrugar",
+ "tearing": "Rasgar",
+ "beep": "Bip",
+ "ping": "Ping",
+ "ding": "Ding",
+ "clang": "Sonido metálico",
+ "squeal": "Chillido",
+ "creak": "Crujido",
+ "rustle": "Crujir",
+ "whir": "Zumbido de ventilador",
+ "clatter": "Estrépito",
+ "sizzle": "Chisporroteo",
+ "clicking": "Click",
+ "clickety_clack": "Clic-clac",
+ "rumble": "Retumbar",
+ "plop": "Plaf",
+ "hum": "Murmullo",
+ "zing": "silbido",
+ "boing": "Bote",
+ "crunch": "Crujido",
+ "sine_wave": "Onda Sinusoidal",
+ "harmonic": "Harmonica",
+ "chirp_tone": "Tono de chirrido",
+ "pulse": "Pulso",
+ "inside": "Dentro",
+ "outside": "Afuera",
+ "reverberation": "Reverberación",
+ "echo": "Eco",
+ "noise": "Ruido",
+ "mains_hum": "Zumbido de red",
+ "distortion": "Distorsión",
+ "sidetone": "Tono lateral",
+ "cacophony": "Cacofonía",
+ "throbbing": "Palpitación",
+ "vibration": "Vibración",
+ "sodeling": "Sodeling",
+ "chird": "Chird",
+ "change_ringing": "Cambio timbre"
}
diff --git a/web/public/locales/es/common.json b/web/public/locales/es/common.json
index bf6a735fa..a953bc5b9 100644
--- a/web/public/locales/es/common.json
+++ b/web/public/locales/es/common.json
@@ -87,7 +87,11 @@
"formattedTimestampMonthDayYear": {
"12hour": "MMM d, yyyy",
"24hour": "MMM d, yyyy"
- }
+ },
+ "inProgress": "En progreso",
+ "invalidStartTime": "Hora de inicio no válida",
+ "invalidEndTime": "Hora de finalización no válida",
+ "never": "Nunca"
},
"menu": {
"settings": "Ajustes",
@@ -141,7 +145,15 @@
"fr": "Français (Frances)",
"yue": "粵語 (Cantonés)",
"th": "ไทย (Tailandés)",
- "ca": "Català (Catalan)"
+ "ca": "Català (Catalan)",
+ "ptBR": "Português brasileiro (Portugués brasileño)",
+ "sr": "Српски (Serbio)",
+ "sl": "Slovenščina (Esloveno)",
+ "lt": "Lietuvių (Lituano)",
+ "bg": "Български (Búlgaro)",
+ "gl": "Galego (Gallego)",
+ "id": "Bahasa Indonesia (Indonesio)",
+ "ur": "اردو (Urdu)"
},
"appearance": "Apariencia",
"darkMode": {
@@ -181,7 +193,8 @@
"review": "Revisar",
"explore": "Explorar",
"uiPlayground": "Zona de pruebas de la interfaz de usuario",
- "faceLibrary": "Biblioteca de rostros"
+ "faceLibrary": "Biblioteca de rostros",
+ "classification": "Clasificación"
},
"unit": {
"speed": {
@@ -191,6 +204,14 @@
"length": {
"meters": "Metros",
"feet": "Pies"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/hora",
+ "mbph": "MB/hora",
+ "gbph": "GB/hora"
}
},
"button": {
@@ -228,7 +249,8 @@
"enabled": "Habilitado",
"saving": "Guardando…",
"exitFullscreen": "Salir de pantalla completa",
- "on": "ENCENDIDO"
+ "on": "ENCENDIDO",
+ "continue": "Continuar"
},
"toast": {
"save": {
@@ -241,7 +263,13 @@
"copyUrlToClipboard": "URL copiada al portapapeles."
},
"label": {
- "back": "Volver atrás"
+ "back": "Volver atrás",
+ "hide": "Ocultar {{item}}",
+ "show": "Mostrar {{item}}",
+ "ID": "ID",
+ "none": "Ninguno",
+ "all": "Todas",
+ "other": "Otro"
},
"role": {
"title": "Rol",
@@ -271,5 +299,18 @@
"title": "404",
"desc": "Página no encontrada"
},
- "selectItem": "Seleccionar {{item}}"
+ "selectItem": "Seleccionar {{item}}",
+ "readTheDocumentation": "Leer la documentación",
+ "information": {
+ "pixels": "{{area}}px"
+ },
+ "list": {
+ "two": "{{0}} y {{1}}",
+ "many": "{{items}}, y {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Opcional",
+ "internalID": "La ID interna que usa Frigate en la configuración y en la base de datos"
+ }
}
diff --git a/web/public/locales/es/components/auth.json b/web/public/locales/es/components/auth.json
index fde9c5a9f..62d6c8445 100644
--- a/web/public/locales/es/components/auth.json
+++ b/web/public/locales/es/components/auth.json
@@ -10,6 +10,7 @@
"loginFailed": "Error de inicio de sesión"
},
"password": "Contraseña",
- "login": "Iniciar sesión"
+ "login": "Iniciar sesión",
+ "firstTimeLogin": "¿Estás tratando de iniciar sesión por primera vez? Las credenciales están impresas en los registros de Frigate."
}
}
diff --git a/web/public/locales/es/components/camera.json b/web/public/locales/es/components/camera.json
index bf036e0ae..69605875e 100644
--- a/web/public/locales/es/components/camera.json
+++ b/web/public/locales/es/components/camera.json
@@ -66,7 +66,8 @@
"desc": "Cambia las opciones de transmisión en vivo para el panel de control de este grupo de cámaras. Estos ajustes son específicos del dispositivo/navegador.",
"placeholder": "Elige una transmisión",
"stream": "Transmitir"
- }
+ },
+ "birdseye": "Vista Aérea"
}
},
"debug": {
diff --git a/web/public/locales/es/components/dialog.json b/web/public/locales/es/components/dialog.json
index 376b385e6..98c96528f 100644
--- a/web/public/locales/es/components/dialog.json
+++ b/web/public/locales/es/components/dialog.json
@@ -66,10 +66,11 @@
"toast": {
"error": {
"failed": "No se pudo iniciar la exportación: {{error}}",
- "noVaildTimeSelected": "No se seleccionó un rango de tiempo válido.",
- "endTimeMustAfterStartTime": "La hora de finalización debe ser posterior a la hora de inicio."
+ "noVaildTimeSelected": "No se seleccionó un rango de tiempo válido",
+ "endTimeMustAfterStartTime": "La hora de finalización debe ser posterior a la hora de inicio"
},
- "success": "Exportación iniciada con éxito. Ver el archivo en la carpeta /exports."
+ "success": "Exportación iniciada con éxito. Ver el archivo en la página exportaciones.",
+ "view": "Ver"
},
"fromTimeline": {
"saveExport": "Guardar exportación",
@@ -120,7 +121,16 @@
"button": {
"export": "Exportar",
"markAsReviewed": "Marcar como revisado",
- "deleteNow": "Eliminar ahora"
+ "deleteNow": "Eliminar ahora",
+ "markAsUnreviewed": "Marcar como no revisado"
}
+ },
+ "imagePicker": {
+ "selectImage": "Seleccione la miniatura de un objeto rastreado",
+ "search": {
+ "placeholder": "Búsqueda por etiqueta o sub-etiqueta..."
+ },
+ "noImages": "No se encontraron miniaturas para esta cámara",
+ "unknownLabel": "Imagen de activación guardada"
}
}
diff --git a/web/public/locales/es/components/filter.json b/web/public/locales/es/components/filter.json
index 7c627ad5f..49e3c3347 100644
--- a/web/public/locales/es/components/filter.json
+++ b/web/public/locales/es/components/filter.json
@@ -119,9 +119,23 @@
"loading": "Cargando matrículas reconocidas…",
"placeholder": "Escribe para buscar matrículas…",
"noLicensePlatesFound": "No se encontraron matrículas.",
- "selectPlatesFromList": "Selecciona una o más matrículas de la lista."
+ "selectPlatesFromList": "Selecciona una o más matrículas de la lista.",
+ "selectAll": "Seleccionar todas",
+ "clearAll": "Limpiar todas"
},
"zoneMask": {
"filterBy": "Filtrar por máscara de zona"
+ },
+ "classes": {
+ "label": "Clases",
+ "all": {
+ "title": "Todas las Clases"
+ },
+ "count_one": "{{count}} Clase",
+ "count_other": "{{count}} Clases"
+ },
+ "attributes": {
+ "label": "Atributos de Clasificación",
+ "all": "Todos los Atributos"
}
}
diff --git a/web/public/locales/es/objects.json b/web/public/locales/es/objects.json
index 0e972102c..0fd02208a 100644
--- a/web/public/locales/es/objects.json
+++ b/web/public/locales/es/objects.json
@@ -102,7 +102,7 @@
"baseball_bat": "Bate de béisbol",
"oven": "Horno",
"waste_bin": "Papelera",
- "snowboard": "Snowboard",
+ "snowboard": "Tabla de Snow",
"sandwich": "Sandwich",
"fox": "Zorro",
"nzpost": "NZPost",
diff --git a/web/public/locales/es/views/classificationModel.json b/web/public/locales/es/views/classificationModel.json
new file mode 100644
index 000000000..f70c69bf1
--- /dev/null
+++ b/web/public/locales/es/views/classificationModel.json
@@ -0,0 +1,192 @@
+{
+ "documentTitle": "Modelos de Clasificación - Frigate",
+ "button": {
+ "deleteClassificationAttempts": "Borrar Imágenes de Clasificación",
+ "renameCategory": "Renombrar Clase",
+ "deleteCategory": "Borrar Clase",
+ "deleteImages": "Borrar Imágenes",
+ "trainModel": "Entrenar Modelo",
+ "addClassification": "Añadir Clasificación",
+ "deleteModels": "Borrar Modelos",
+ "editModel": "Editar Modelo"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Clase Borrada",
+ "deletedImage": "Imágenes Borradas",
+ "deletedModel_one": "Borrado con éxito {{count}} modelo",
+ "deletedModel_many": "Borrados con éxito {{count}} modelos",
+ "deletedModel_other": "Borrados con éxito {{count}} modelos",
+ "categorizedImage": "Imagen Clasificada Correctamente",
+ "trainedModel": "Modelo entrenado correctamente.",
+ "trainingModel": "Entrenamiento del modelo iniciado correctamente.",
+ "updatedModel": "Configuración del modelo actualizada correctamente",
+ "renamedCategory": "Clase renombrada correctamente a {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Fallo al borrar: {{errorMessage}}",
+ "deleteCategoryFailed": "Fallo al borrar clase: {{errorMessage}}",
+ "deleteModelFailed": "Fallo al borrar modelo: {{errorMessage}}",
+ "categorizeFailed": "Fallo al categorizar imagen: {{errorMessage}}",
+ "trainingFailed": "El entrenamiento del modelo ha fallado. Revisa los registros de Frigate para más detalles.",
+ "updateModelFailed": "Fallo al actualizar modelo: {{errorMessage}}",
+ "trainingFailedToStart": "No se pudo iniciar el entrenamiento del modelo: {{errorMessage}}",
+ "renameCategoryFailed": "Falló el renombrado de la clase: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Borrar Clase",
+ "desc": "¿Esta seguro de que quiere borrar la clase {{name}}? Esto borrará permanentemente todas las imágenes asociadas y requerirá reentrenar el modelo.",
+ "minClassesTitle": "No se puede Borrar la Clase",
+ "minClassesDesc": "Un modelo de clasificación debe tener al menos 2 clases. Añade otra clase antes de borrar esta."
+ },
+ "deleteModel": {
+ "title": "Borrar Modelo de Clasificación",
+ "single": "¿Está seguro de que quiere eliminar {{name}}? Esto borrar permanentemente todos los datos asociados incluidas las imágenes y los datos de entrenamiento. Esta acción no se puede deshacer.",
+ "desc_one": "¿Estas seguro de que quiere borrar {{count}} modelo? Esto borrara permanentemente todos los datos asociados, incluyendo imágenes y datos de entrenamiento. Esta acción no puede ser desehecha.",
+ "desc_many": "¿Estas seguro de que quiere borrar {{count}} modelos? Esto borrara permanentemente todos los datos asociados, incluyendo imágenes y datos de entrenamiento. Esta acción no puede ser desehecha.",
+ "desc_other": "¿Estas seguro de que quiere borrar {{count}} modelos? Esto borrara permanentemente todos los datos asociados, incluyendo imágenes y datos de entrenamiento. Esta acción no puede ser desehecha."
+ },
+ "edit": {
+ "title": "Editar modelo de clasificación",
+ "descriptionState": "Edita las clases para este modelo de clasificación de estados. Los cambios requerirán un reentrenamiento de modelo.",
+ "descriptionObject": "Edita el tipo de objeto y el tipo de clasificación para este modelo de clasificación de objetos.",
+ "stateClassesInfo": "Nota: El cambio de las clases de estado requiere reentrenar el modelo con las clases actualizadas."
+ },
+ "tooltip": {
+ "noChanges": "No se han realizado cambios en el conjunto de datos desde el último entrenamiento.",
+ "modelNotReady": "El modelo no está listo para el entrenamiento",
+ "trainingInProgress": "El modelo está entrenándose actualmente",
+ "noNewImages": "No hay imágenes nuevas para entrenar. Clasifica antes más imágenes del conjunto de datos."
+ },
+ "details": {
+ "scoreInfo": "La puntuación representa la confianza media de clasificación en todas las detecciones de este objeto.",
+ "unknown": "Desconocido",
+ "none": "Ninguna"
+ },
+ "categorizeImage": "Clasificar Imagen",
+ "menu": {
+ "objects": "Objetos",
+ "states": "Estados"
+ },
+ "wizard": {
+ "steps": {
+ "chooseExamples": "Seleccionar Ejemplos",
+ "nameAndDefine": "Nombrar y definir",
+ "stateArea": "Área de estado"
+ },
+ "step1": {
+ "name": "Nombre",
+ "namePlaceholder": "Introducir nombre del modelo...",
+ "type": "Tipo",
+ "typeState": "Estado",
+ "typeObject": "Objeto",
+ "objectLabel": "Etiqueta de Objeto",
+ "objectLabelPlaceholder": "Seleccionar tipo de objeto...",
+ "classificationAttribute": "Atributo",
+ "classes": "Clases",
+ "states": "Estados",
+ "classPlaceholder": "Introducir nombre de la clase...",
+ "errors": {
+ "nameRequired": "Se requiere nombre del modelo",
+ "nameLength": "El nombre del modelo debe tener 64 caracteres o menos",
+ "nameOnlyNumbers": "El nombre del modelo no puede contener solo números",
+ "classRequired": "Al menos se requiere una clase",
+ "classesUnique": "Los nombres de clase deben ser únicos",
+ "noneNotAllowed": "La clase 'none' no esta permitida",
+ "stateRequiresTwoClasses": "Los modelos de estado requieren al menos 2 clases",
+ "objectLabelRequired": "Por favor seleccione una etiqueta de objeto",
+ "objectTypeRequired": "Por favor seleccione un tipo de clasificación"
+ },
+ "description": "Los modelos de estado monitorean las áreas fijas de la cámara para detectar cambios (p. ej., puerta abierta/cerrada). Los modelos de objetos clasifican los objetos detectados (p. ej., animales conocidos, repartidores, etc.).",
+ "classificationType": "Tipo de clasificación",
+ "classificationTypeTip": "Conozca más sobre los tipos de clasificación",
+ "classificationTypeDesc": "Las subetiquetas añaden texto adicional a la etiqueta del objeto (p. ej., «Persona: UPS»). Los atributos son metadatos que permiten búsquedas y se almacenan por separado en los metadatos del objeto.",
+ "classificationSubLabel": "Sub etiqueta",
+ "classesTip": "Aprenda más sobre clases",
+ "classesStateDesc": "Define los diferentes estados en los que puede estar el área de tu cámara. Por ejemplo: \"abierta\" y \"cerrada\" para una puerta de garaje.",
+ "classesObjectDesc": "Define las diferentes categorías para clasificar los objetos detectados. Por ejemplo: \"persona de reparto\", \"residente\" y \"desconocido\" para la clasificación de personas."
+ },
+ "step2": {
+ "description": "Seleccione las cámaras y defina el area a monitorizar por cada cámara. El modelo clasificará el estado de estas cámaras.",
+ "cameras": "Camaras",
+ "selectCamera": "Selecciones Cámara",
+ "noCameras": "Haga clic en + para añadir cámaras",
+ "selectCameraPrompt": "Seleccione una cámara de la lista para definir su área de monitorización"
+ },
+ "step3": {
+ "selectImagesPrompt": "Seleccione todas las imágenes de: {{className}}",
+ "selectImagesDescription": "Haga clic en las imágenes para seleccionarlas. Haga clic en Continuar cuando esté listo para esta clase.",
+ "generating": {
+ "title": "Generando Imágenes de Ejemplo",
+ "description": "Frigate está seleccionando imágenes representativas de sus grabaciones. Esto puede llevar un tiempo..."
+ },
+ "training": {
+ "title": "Modelo de Entrenamiento",
+ "description": "Tu modelo se está entrenando en segundo plano. Cierra este cuadro de diálogo y tu modelo comenzará a ejecutarse en cuanto finalice el entrenamiento."
+ },
+ "retryGenerate": "Reintentar Generación",
+ "noImages": "No se han generado imágenes de ejemplo",
+ "classifying": "Clasificando y Entrenando...",
+ "trainingStarted": "Entrenamiento iniciado con éxito",
+ "modelCreated": "Modelo creado con éxito. Use la vista de Clasificaciones Recientes para añadir imágenes para los estados que falten, después entrene el modelo.",
+ "errors": {
+ "noCameras": "No hay cámaras configuradas",
+ "noObjectLabel": "No se ha seleccionado etiqueta de objeto",
+ "generateFailed": "Falló la generación de ejemplos: {{error}}",
+ "generationFailed": "Generación fallida. Por favor pruebe otra vez.",
+ "classifyFailed": "Falló la clasificación de imágenes: {{error}}"
+ },
+ "generateSuccess": "Imágenes de ejemplo generadas correctamente",
+ "missingStatesWarning": {
+ "title": "Faltan Ejemplos de Estado",
+ "description": "Se recomienda seleccionar ejemplos para todos los estados para obtener mejores resultados. Puede continuar sin seleccionar todos los estados, pero el modelo no se entrenará hasta que todos los estados tengan imágenes. Después de continuar, use la vista \"Clasificaciones recientes\" para clasificar las imágenes de los estados faltantes y luego entrene el modelo."
+ },
+ "allImagesRequired_one": "Por favor clasifique todas las imágenes. Queda {{count}} imagen.",
+ "allImagesRequired_many": "Por favor clasifique todas las imágenes. Quedan {{count}} imágenes.",
+ "allImagesRequired_other": "Por favor clasifique todas las imágenes. Quedan {{count}} imágenes."
+ },
+ "title": "Crear nueva Clasificación"
+ },
+ "deleteDatasetImages": {
+ "title": "Borrar Conjunto de Imágenes",
+ "desc_one": "¿Está seguro de que quiere eliminar {{count}} imagen de {{dataset}}? Esta acción no puede ser deshecha y requerirá reentrenar el modelo.",
+ "desc_many": "¿Está seguro de que quiere eliminar {{count}} imágenes de {{dataset}}? Esta acción no puede ser deshecha y requerirá reentrenar el modelo.",
+ "desc_other": "¿Está seguro de que quiere eliminar {{count}} imágenes de {{dataset}}? Esta acción no puede ser deshecha y requerirá reentrenar el modelo."
+ },
+ "deleteTrainImages": {
+ "title": "Borrar Imágenes de Entrenamiento",
+ "desc_one": "¿Está seguro de que quiere eliminar {{count}} imagen? Esta acción no puede ser deshecha.",
+ "desc_many": "¿Está seguro de que quiere eliminar {{count}} imágenes? Esta acción no puede ser deshecha.",
+ "desc_other": "¿Está seguro de que quiere eliminar {{count}} imágenes? Esta acción no puede ser deshecha."
+ },
+ "renameCategory": {
+ "title": "Renombrar Clase",
+ "desc": "Introduzca un nuevo nombre para {{name}}. Se requerirá que reentrene el modelo para que el cambio de nombre tenga efecto."
+ },
+ "description": {
+ "invalidName": "Nombre incorrecto. Los nombres solo pueden incluir letras, números, espacios, apóstrofes, guiones bajos, y guiones."
+ },
+ "train": {
+ "title": "Clasificaciones Recientes",
+ "titleShort": "Reciente",
+ "aria": "Seleccione Clasificaciones Recientes"
+ },
+ "categories": "Clases",
+ "createCategory": {
+ "new": "Crear Nueva Clase"
+ },
+ "categorizeImageAs": "Clasificar Imagen Como:",
+ "noModels": {
+ "object": {
+ "title": "No hay Modelos de Clasificación de Objetos",
+ "description": "Crear modelo a medida para clasificar los objetos detectados.",
+ "buttonText": "Crear Modelo de Objetos"
+ },
+ "state": {
+ "title": "No hay Modelos de Clasificación de Estados",
+ "description": "Cree un modelo personalizado para monitorear y clasificar los cambios de estado en áreas específicas de la cámara.",
+ "buttonText": "Crear modelo de estado"
+ }
+ }
+}
diff --git a/web/public/locales/es/views/configEditor.json b/web/public/locales/es/views/configEditor.json
index 39514ec82..265e7ec8e 100644
--- a/web/public/locales/es/views/configEditor.json
+++ b/web/public/locales/es/views/configEditor.json
@@ -12,5 +12,7 @@
}
},
"documentTitle": "Editor de Configuración - Frigate",
- "confirm": "¿Salir sin guardar?"
+ "confirm": "¿Salir sin guardar?",
+ "safeConfigEditor": "Editor de Configuración (Modo Seguro)",
+ "safeModeDescription": "Frigate esta en modo seguro debido a un error en la validación de la configuración."
}
diff --git a/web/public/locales/es/views/events.json b/web/public/locales/es/views/events.json
index b06cd92e9..d13daff60 100644
--- a/web/public/locales/es/views/events.json
+++ b/web/public/locales/es/views/events.json
@@ -9,7 +9,11 @@
"empty": {
"alert": "No hay alertas para revisar",
"detection": "No hay detecciones para revisar",
- "motion": "No se encontraron datos de movimiento"
+ "motion": "No se encontraron datos de movimiento",
+ "recordingsDisabled": {
+ "title": "Las grabaciones deben estar habilitadas",
+ "description": "Solo se pueden crear elementos de revisión para una cámara cuando las grabaciones están habilitadas para esa cámara."
+ }
},
"timeline": "Línea de tiempo",
"timeline.aria": "Seleccionar línea de tiempo",
@@ -35,5 +39,30 @@
"selected": "{{count}} seleccionados",
"selected_one": "{{count}} seleccionados",
"selected_other": "{{count}} seleccionados",
- "detected": "detectado"
+ "detected": "detectado",
+ "suspiciousActivity": "Actividad Sospechosa",
+ "threateningActivity": "Actividad Amenzadora",
+ "zoomIn": "Agrandar",
+ "zoomOut": "Alejar",
+ "detail": {
+ "label": "Detalle",
+ "trackedObject_one": "{{count}} objeto",
+ "trackedObject_other": "{{count}} objetos",
+ "noObjectDetailData": "No hay datos detallados del objeto.",
+ "settings": "Configuración de la Vista Detalle",
+ "noDataFound": "No hay datos detallados para revisar",
+ "aria": "Alternar vista de detalles",
+ "alwaysExpandActive": {
+ "title": "Expandir siempre los activos",
+ "desc": "Expandir siempre los detalles del objeto activo cuando esten disponibles."
+ }
+ },
+ "objectTrack": {
+ "clickToSeek": "Clic para ir a este momento",
+ "trackedPoint": "Puntro trazado"
+ },
+ "select_all": "Todas",
+ "normalActivity": "Normal",
+ "needsReview": "Necesita revisión",
+ "securityConcern": "Aviso de seguridad"
}
diff --git a/web/public/locales/es/views/explore.json b/web/public/locales/es/views/explore.json
index f5fb869e0..f8f61ce83 100644
--- a/web/public/locales/es/views/explore.json
+++ b/web/public/locales/es/views/explore.json
@@ -41,12 +41,16 @@
"success": {
"updatedSublabel": "Subetiqueta actualizada con éxito.",
"regenerate": "Se ha solicitado una nueva descripción a {{provider}}. Dependiendo de la velocidad de tu proveedor, la nueva descripción puede tardar algún tiempo en regenerarse.",
- "updatedLPR": "Matrícula actualizada con éxito."
+ "updatedLPR": "Matrícula actualizada con éxito.",
+ "audioTranscription": "Se solicitó correctamente la transcripción de audio. Dependiendo de la velocidad de su servidor Frigate, la transcripción puede tardar un tiempo.",
+ "updatedAttributes": "Atributos actualizados correctamente."
},
"error": {
"regenerate": "No se pudo llamar a {{provider}} para una nueva descripción: {{errorMessage}}",
"updatedSublabelFailed": "No se pudo actualizar la subetiqueta: {{errorMessage}}",
- "updatedLPRFailed": "No se pudo actualizar la matrícula: {{errorMessage}}"
+ "updatedLPRFailed": "No se pudo actualizar la matrícula: {{errorMessage}}",
+ "audioTranscription": "Transcripción de audio solicitada falló: {{errorMessage}}",
+ "updatedAttributesFailed": "No se pudieron actualizar los atributos: {{errorMessage}}"
}
},
"tips": {
@@ -97,6 +101,17 @@
"recognizedLicensePlate": "Matrícula Reconocida",
"snapshotScore": {
"label": "Puntuación de Instantánea"
+ },
+ "score": {
+ "label": "Puntuación"
+ },
+ "editAttributes": {
+ "title": "Editar atributos",
+ "desc": "Seleccione atributos de clasificación para esta {{label}}"
+ },
+ "attributes": "Atributos de clasificación",
+ "title": {
+ "label": "Título"
}
},
"documentTitle": "Explorar - Frigate",
@@ -105,7 +120,9 @@
"snapshot": "captura instantánea",
"video": "vídeo",
"object_lifecycle": "ciclo de vida del objeto",
- "details": "detalles"
+ "details": "detalles",
+ "thumbnail": "miniatura",
+ "tracking_details": "detalles de seguimiento"
},
"objectLifecycle": {
"title": "Ciclo de vida del objeto",
@@ -183,12 +200,34 @@
},
"deleteTrackedObject": {
"label": "Eliminar este objeto rastreado"
+ },
+ "audioTranscription": {
+ "label": "Transcribir",
+ "aria": "Solicitar transcripción de audio"
+ },
+ "addTrigger": {
+ "label": "Añadir disparador",
+ "aria": "Añadir disparador para el objeto seguido"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Descargue instantánea limpia",
+ "aria": "Descargue instantánea limpia"
+ },
+ "viewTrackingDetails": {
+ "label": "Ver detalles de seguimiento",
+ "aria": "Ver detalles de seguimiento"
+ },
+ "showObjectDetails": {
+ "label": "Mostrar la ruta del objeto"
+ },
+ "hideObjectDetails": {
+ "label": "Ocultar la ruta del objeto"
}
},
"dialog": {
"confirmDelete": {
"title": "Confirmar eliminación",
- "desc": "Eliminar este objeto rastreado elimina la captura de pantalla, cualquier incrustación guardada y cualquier entrada asociada al ciclo de vida del objeto. Las grabaciones de este objeto rastreado en la vista de Historial NO se eliminarán.Rutas
Líneas y círculos indicarán los puntos significativos por los que se ha movido el objeto rastreado durante su ciclo de vida.
" + }, + "openCameraWebUI": "Abrir Web UI de {{camera}}", + "audio": { + "title": "Audio", + "noAudioDetections": "No hay detecciones de audio", + "score": "puntuación", + "currentRMS": "RMS actual", + "currentdbFS": "dbFS actual" } }, "users": { @@ -452,7 +518,7 @@ "role": "Rol", "noUsers": "No se encontraron usuarios.", "changeRole": "Cambiar el rol del usuario", - "password": "Contraseña", + "password": "Restablecer Contraseña", "deleteUser": "Eliminar usuario" }, "dialog": { @@ -477,7 +543,16 @@ "veryStrong": "Muy fuerte" }, "match": "Las contraseñas coinciden", - "notMatch": "Las contraseñas no coinciden" + "notMatch": "Las contraseñas no coinciden", + "show": "Mostrar contraseña", + "hide": "Ocultar contraseña", + "requirements": { + "title": "Requisitos de contraseña:", + "length": "Al menos 8 caracteres", + "uppercase": "Al menos una mayúscula", + "digit": "Al menos un número", + "special": "Al menos un caracter especial (!@#$%^&*(),.?\":{}|<>)" + } }, "newPassword": { "title": "Nueva contraseña", @@ -487,14 +562,23 @@ } }, "usernameIsRequired": "Se requiere el nombre de usuario", - "passwordIsRequired": "Se requiere contraseña" + "passwordIsRequired": "Se requiere contraseña", + "currentPassword": { + "title": "Contraseña actual", + "placeholder": "Introduzca su contraseña actual" + } }, "passwordSetting": { "updatePassword": "Actualizar contraseña para {{username}}", "setPassword": "Establecer contraseña", "desc": "Crear una contraseña fuerte para asegurar esta cuenta.", "cannotBeEmpty": "La contraseña no puede estar vacía", - "doNotMatch": "Las contraseñas no coinciden" + "doNotMatch": "Las contraseñas no coinciden", + "currentPasswordRequired": "Se requiere la contraseña actual", + "incorrectCurrentPassword": "La contraseña actual es incorrecta", + "passwordVerificationFailed": "Fallo al verificar la contraseña", + "multiDeviceWarning": "Cualquier otro dispositivo en el que haya iniciado sesión deberá iniciar sesión nuevamente con {{refresh_time}}.", + "multiDeviceAdmin": "También puede obligar a todos los usuarios a volver a autenticarse inmediatamente rotando su secreto JWT." }, "createUser": { "desc": "Añadir una nueva cuenta de usuario y especificar un rol para el acceso a áreas de la interfaz de usuario de Frigate.", @@ -510,7 +594,8 @@ "adminDesc": "Acceso completo a todas las funciones.", "viewerDesc": "Limitado a paneles en vivo, revisión, exploración y exportaciones únicamente.", "viewer": "Espectador", - "admin": "Administrador" + "admin": "Administrador", + "customDesc": "Rol personalizado con acceso a cámaras." }, "select": "Selecciona un rol" }, @@ -520,7 +605,7 @@ "desc": "Esta acción no se puede deshacer. Esto eliminará permanentemente la cuenta de usuario y eliminará todos los datos asociados." } }, - "updatePassword": "Actualizar contraseña" + "updatePassword": "Restablecer contraseña" }, "notification": { "title": "Notificaciones", @@ -623,7 +708,7 @@ "unsavedChanges": "Cambios en la configuración de Frigate+ no guardados" }, "enrichments": { - "title": "Configuración de Análisis Avanzado", + "title": "Configuración de Enriquecimientos", "unsavedChanges": "Cambios sin guardar en la configuración de Análisis Avanzado", "birdClassification": { "title": "Clasificación de Aves", @@ -683,5 +768,460 @@ "success": "Los ajustes de enriquecimientos se han guardado. Reinicia Frigate para aplicar los cambios.", "error": "No se pudieron guardar los cambios en la configuración: {{errorMessage}}" } + }, + "triggers": { + "documentTitle": "Disparadores", + "management": { + "title": "Disparadores", + "desc": "Gestionar disparadores para {{camera}}. Usa el tipo de miniatura para activar en miniaturas similares al objeto rastreado seleccionado, y el tipo de descripción para activar en descripciones similares al texto que especifiques." + }, + "addTrigger": "Añadir Disparador", + "table": { + "name": "Nombre", + "type": "Tipo", + "content": "Contenido", + "threshold": "Umbral", + "actions": "Acciones", + "noTriggers": "No hay disparadores configurados para esta cámara.", + "edit": "Editar", + "deleteTrigger": "Eliminar Disparador", + "lastTriggered": "Última activación" + }, + "type": { + "description": "Descripción", + "thumbnail": "Miniatura" + }, + "actions": { + "alert": "Marcar como Alerta", + "notification": "Enviar Notificación", + "sub_label": "Añadir una subetiqueta", + "attribute": "Añadir atributo" + }, + "dialog": { + "createTrigger": { + "title": "Crear Disparador", + "desc": "Crear un disparador par la cámara {{camera}}" + }, + "editTrigger": { + "title": "Editar Disparador", + "desc": "Editar configuractión del disparador para cámara {{camera}}" + }, + "deleteTrigger": { + "title": "Eliminar Disparador", + "desc": "Está seguro de que desea eliminar el disparador {{triggerName}}? Esta acción no se puede deshacer." + }, + "form": { + "name": { + "title": "Nombre", + "placeholder": "Asigne nombre a este disparador", + "error": { + "minLength": "El campo debe tener al menos 2 caracteres.", + "invalidCharacters": "El campo sólo puede contener letras, números, guiones bajos, y guiones.", + "alreadyExists": "Un disparador con este nombre ya existe para esta cámara." + }, + "description": "Ingrese un nombre o descripción únicos para identificar este disparador" + }, + "enabled": { + "description": "Activa o desactiva este disparador" + }, + "type": { + "title": "Tipo", + "placeholder": "Seleccione tipo de disparador", + "description": "Se dispara cuando se detecta una descripción de objeto rastreado similar", + "thumbnail": "Se dispara cuando se detecta una miniatura de un objeto rastreado similar" + }, + "friendly_name": { + "title": "Nombre amigable", + "placeholder": "Nombre o describa este disparador", + "description": "Un nombre o texto descriptivo amigable (opcional) para este disparador." + }, + "content": { + "title": "Contenido", + "imagePlaceholder": "Seleccione una imagen", + "textPlaceholder": "Entre contenido de texto", + "error": { + "required": "El contenido es requrido." + }, + "imageDesc": "Solo se muestran las 100 miniaturas más recientes. Si no encuentra la miniatura que busca, revise los objetos anteriores en Explorar y configure un disparador desde el menú.", + "textDesc": "Entre texto para iniciar esta acción cuando la descripción de un objecto seguido similar es detectado." + }, + "threshold": { + "title": "Umbral", + "error": { + "min": "El umbral debe ser al menos 0", + "max": "El umbral debe ser al menos 1" + }, + "desc": "Establezca el umbral de similitud para este disparador. Un umbral más alto significa que se requiere una coincidencia más cercana para activar el disparador." + }, + "actions": { + "title": "Acciones", + "error": { + "min": "Al menos una acción debe ser seleccionada." + }, + "desc": "Por defecto, Frigate manda un mensaje MQTT para todos los disparadores. Las subetiquetas añaden el nombre del disparador a la etiqueta del objeto. Los atributos son metadatos de búsqueda que se almacenan por separado en los metadatos del objeto rastreado." + } + } + }, + "semanticSearch": { + "title": "Búsqueda semántica desactivada", + "desc": "Búsqueda semántica debe estar activada para usar Disparadores." + }, + "toast": { + "success": { + "createTrigger": "Disparador {{name}} creado exitosamente.", + "updateTrigger": "Disparador {{name}} actualizado exitosamente.", + "deleteTrigger": "Disparador {{name}} eliminado exitosamente." + }, + "error": { + "createTriggerFailed": "Fallo al crear el disparador: {{errorMessage}}", + "updateTriggerFailed": "Fallo al actualizar el disparador: {{errorMessage}}", + "deleteTriggerFailed": "Fallo al eliminar el disparador: {{errorMessage}}" + } + }, + "wizard": { + "title": "Crear disparador", + "step1": { + "description": "Configure los ajustes básicos para su disparador." + }, + "step2": { + "description": "Configure el contenido que activará esta acción." + }, + "step3": { + "description": "Configure el umbral y las acciones para este disparador." + }, + "steps": { + "nameAndType": "Nombre y tipo", + "configureData": "Configurar datos", + "thresholdAndActions": "Umbral y acciones" + } + } + }, + "roles": { + "management": { + "title": "Administración del rol de visor", + "desc": "Administra roles de visor personalizados y sus permisos de acceso a cámaras para esta instancia de Frigate." + }, + "addRole": "Añade un rol", + "table": { + "role": "Rol", + "cameras": "Cámaras", + "actions": "Acciones", + "noRoles": "No se encontraron roles personalizados.", + "editCameras": "Edita Cámaras", + "deleteRole": "Eliminar Rol" + }, + "toast": { + "success": { + "createRole": "Rol {{role}} creado exitosamente", + "updateCameras": "Cámara actualizada para el rol {{role}}", + "deleteRole": "Rol {{role}} eliminado exitosamente", + "userRolesUpdated_one": "{{count}} usuario asignado a este rol ha sido actualizado a 'revisor', que tiene acceso a todas las cámaras.", + "userRolesUpdated_many": "{{count}} usuarios asignados a este rol han sido actualizado a 'revisor', que tienen acceso a todas las cámaras.", + "userRolesUpdated_other": "{{count}} usuarios asignados a este rol han sido actualizado a 'revisor', que tienen acceso a todas las cámaras." + }, + "error": { + "createRoleFailed": "Creación de rol fallida: {{errorMessage}}", + "updateCamerasFailed": "Actualización de cámaras fallida: {{errorMessage}}", + "deleteRoleFailed": "Eliminación de rol fallida: {{errorMessage}}", + "userUpdateFailed": "Actualización de roles de usuario fallida: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Crear Nuevo Rol", + "desc": "Añadir nuevo rol y especificar permisos de acceso a cámaras." + }, + "deleteRole": { + "title": "Eliminar Rol", + "deleting": "Eliminando...", + "desc": "Esta acción no se puede deshacer. El rol va a ser eliminado permanentemente y usuarios associados serán asignados a rol de 'Visor', que les da acceso a ver todas las cámaras.", + "warn": "Estás seguro de que quieres eliminar {{role}}?" + }, + "editCameras": { + "title": "Editar cámaras de rol", + "desc": "Actualizar acceso de cámara para el rol {{role}}." + }, + "form": { + "role": { + "title": "Nombre de rol", + "placeholder": "Entre el nombre del rol", + "desc": "Solo se permiten letras, números, puntos y guión bajo.", + "roleIsRequired": "El nombre del rol es requerido", + "roleOnlyInclude": "El nombre del rol solo incluye letras, números, . o _", + "roleExists": "Un rol con este nombre ya existe." + }, + "cameras": { + "title": "Cámaras", + "desc": "Seleccione las cámaras a las que este rol tiene accceso. Al menos una cámara es requerida.", + "required": "Al menos una cámara debe ser seleccionada." + } + } + } + }, + "cameraWizard": { + "step1": { + "errors": { + "nameRequired": "El nombre de la cámara es un campo obligatorio", + "nameLength": "El nombre de la cámara debe tener 64 caracteres o menos", + "invalidCharacters": "El nombre de la cámara contiene caracteres no válidos", + "nameExists": "El nombre de la cámara ya existe", + "customUrlRtspRequired": "Las URL personalizadas deben comenzar con \"rtsp://\". Se requiere configuración manual para transmisiones de cámara sin RTSP.", + "brandOrCustomUrlRequired": "Seleccione una marca de cámara con host/IP o elija \"Otro\" con una URL personalizada" + }, + "description": "Ingrese los detalles de su cámara y elija probar la cámara o seleccionar manualmente la marca.", + "cameraName": "Nombre de la Cámara", + "cameraNamePlaceholder": "Ejempo: puerta_principal o Vista del Patio trasero", + "host": "Nombre Host / Dirección IP", + "port": "Puerto", + "username": "Nombre de usuario", + "usernamePlaceholder": "Opcional", + "password": "Contraseña", + "passwordPlaceholder": "Opcional", + "selectTransport": "Seleccionar protocolo de transporte", + "cameraBrand": "Marca de la cámara", + "selectBrand": "Seleccione la marca de la cámara para la plantilla de URL", + "customUrl": "URL de transmisión personalizada", + "brandInformation": "Información de la Marca", + "brandUrlFormat": "Para cámaras con formato de URL RTSP como: {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://usuario:contraseña@hostname:puerto/ruta", + "connectionSettings": "Ajustes de conexión", + "detectionMethod": "Método de detección de transmisión", + "onvifPort": "Puerto ONVIF", + "probeMode": "Cámara de sonda", + "manualMode": "Selección manual", + "detectionMethodDescription": "Pruebe la cámara con ONVIF (si es compatible) para encontrar las URL de transmisión o seleccione manualmente la marca de la cámara para usar las URL predefinidas. Para introducir una URL RTSP personalizada, elija el método manual y seleccione \"Otro\".", + "onvifPortDescription": "Para las cámaras compatibles con ONVIF, normalmente es 80 o 8080.", + "useDigestAuth": "Use autenticación digest", + "useDigestAuthDescription": "Utilice la autenticación HTTP digest para ONVIF. Algunas cámaras pueden requerir un nombre de usuario y contraseña ONVIF específicos en lugar del usuario administrador estándar." + }, + "step2": { + "description": "Pruebe la cámara para detectar transmisiones disponibles o configure ajustes manuales según el método de detección seleccionado.", + "testSuccess": "Test de conexión satisfactorio!", + "testFailed": "Test de conexión fallido. Revise la informacion proporcionada e inténtelo de nuevo.", + "testFailedTitle": "Test fallido", + "streamDetails": "Detalles de la transmisión", + "probing": "Probando la cámara...", + "retry": "Re-intentar", + "testing": { + "probingMetadata": "Probando metadatos de la cámara...", + "fetchingSnapshot": "Obteniendo una instantánea de la cámara..." + }, + "probeFailed": "No se pudo alcanzar la cámara: {{error}}", + "probingDevice": "Probando el dispositivo...", + "probeSuccessful": "Prueba satisfactoria", + "probeError": "Error durante la prueba", + "probeNoSuccess": "Prueba fallida", + "deviceInfo": "Información de Dispositivo", + "manufacturer": "Fabricante", + "model": "Modelo", + "firmware": "Firmware", + "profiles": "Perfiles", + "ptzSupport": "Soporte PTZ", + "autotrackingSupport": "Soporte auto-seguimiento", + "presets": "Preestablecidos", + "rtspCandidates": "Candidatos RTSP", + "rtspCandidatesDescription": "Se encontraron las siguientes URL RTSP durante el sondeo de la cámara. Pruebe la conexión para ver los metadatos de la transmisión.", + "noRtspCandidates": "No se encontraron URL RTSP de la cámara. Es posible que sus credenciales sean incorrectas o que la cámara no sea compatible con ONVIF o el método utilizado para obtener las URL RTSP. Vuelva atrás e introduzca la URL RTSP manualmente.", + "candidateStreamTitle": "Candidato {{number}}", + "useCandidate": "Uso", + "uriCopy": "Copiar", + "uriCopied": "URI copiada al portapapeles", + "testConnection": "Probar conexión", + "toggleUriView": "Haga clic para alternar la vista completa de URI", + "connected": "Conectada", + "notConnected": "No conectada", + "errors": { + "hostRequired": "nombre host/dirección IP requeridos" + } + }, + "step3": { + "description": "Configure los roles de transmisión y agregue transmisiones adicionales para su cámara.", + "streamsTitle": "Transmisiones de cámara", + "addStream": "Añadir ruta de transmisión", + "addAnotherStream": "Añadir otra ruta de transmisión", + "streamTitle": "Transmisión {{number}}", + "streamUrl": "URL de transmisión", + "streamUrlPlaceholder": "rtsp://usuario:contraseña@nombrehost:puerto/ruta", + "selectStream": "Seleccione una transmisión", + "searchCandidates": "Búsqueda de candidatos...", + "noStreamFound": "No se ha encontrado transmisión", + "url": "URL", + "resolution": "Resolución", + "selectResolution": "Seleccione resolución", + "quality": "Calidad", + "selectQuality": "Seleccione calidad", + "roles": "Roles", + "roleLabels": { + "detect": "Detección de objetos", + "record": "Grabando", + "audio": "Audio" + }, + "testStream": "Pruebe la conexión", + "testSuccess": "Test de transmisión satisfactorio!", + "testFailed": "Test de transmisión fallido", + "testFailedTitle": "Prueba falló", + "connected": "Conectado", + "notConnected": "No conectado", + "featuresTitle": "Características", + "go2rtc": "Reduzca conexiones hacia la cámara", + "detectRoleWarning": "al menos una transmisión debe tener el roll de detección para continuar.", + "rolesPopover": { + "title": "Roles de transmisión", + "record": "Guarda segmentos de la transmisión de video según la configuración.", + "detect": "Hilo principal para detección de objetos.", + "audio": "Hilo para detección basada en audio." + }, + "featuresPopover": { + "title": "Características de transmisión", + "description": "Utilice la retransmisión go2rtc para reducir las conexiones a su cámara." + } + }, + "step4": { + "description": "Validación y análisis finales antes de guardar la nueva cámara. Conecte cada transmisión antes de guardar.", + "validationTitle": "Validacion de transmisión", + "connectAllStreams": "Conectar todas las transmisiones", + "reconnectionSuccess": "Reconexión satisfactoria.", + "reconnectionPartial": "Algunas transmisiones no pudieron reconectarse.", + "streamUnavailable": "Vista previa de transmisión no disponible", + "reload": "Recargar", + "connecting": "Conectando...", + "streamTitle": "Transmisión {{number}}", + "valid": "Válido", + "failed": "Falló", + "notTested": "No probado", + "connectStream": "Conectar", + "connectingStream": "Conectando", + "disconnectStream": "Desconectar", + "estimatedBandwidth": "Ancho de banda estimado", + "roles": "Roles", + "ffmpegModule": "Utilice el modo de compatibilidad de transmisión", + "ffmpegModuleDescription": "Si la transmisión no carga después de varios intentos, intenta activar esta opción. Al activarla, Frigate usará el módulo ffmpeg con go2rtc. Esto puede mejorar la compatibilidad con algunas transmisiones de cámara.", + "none": "Ninguna", + "error": "Error", + "streamValidated": "Transmisión {{number}} validada correctamente", + "streamValidationFailed": "Stream {{number}} falló la validación", + "saveAndApply": "Guardar nueva cámara", + "saveError": "Configuración inválida. Revise la configuración.", + "issues": { + "title": "Validación de transmisión", + "videoCodecGood": "El codec de video es {{codec}}.", + "audioCodecGood": "El codec de audio es {{codec}}.", + "resolutionHigh": "Una resolución de {{resolution}} puede provocar un mayor uso de recursos.", + "resolutionLow": "Una resolución de {{resolution}} puede ser demasiado baja para una detección confiable de objetos pequeños.", + "noAudioWarning": "No se detectó audio para esta transmisión, las grabaciones no tendrán audio.", + "audioCodecRecordError": "El códec de audio AAC es necesario para admitir audio en grabaciones.", + "audioCodecRequired": "Se requiere una transmisión de audio para admitir la detección de audio.", + "restreamingWarning": "Reducir las conexiones a la cámara para la transmisión de grabación puede aumentar ligeramente el uso de la CPU.", + "brands": { + "reolink-rtsp": "No se recomienda usar Reolink RTSP. Active HTTP en la configuración del firmware de la cámara y reinicie el asistente.", + "reolink-http": "Las transmisiones HTTP de Reolink deberían usar FFmpeg para una mejor compatibilidad. Active \"Usar modo de compatibilidad de transmisiones\" para esta transmisión." + }, + "dahua": { + "substreamWarning": "La subtransmisión 1 está limitada a una resolución baja. Muchas cámaras Dahua/Amcrest/EmpireTech admiten subtransmisiones adicionales que deben habilitarse en la configuración de la cámara. Se recomienda comprobar y utilizar dichas transmisiones si están disponibles." + }, + "hikvision": { + "substreamWarning": "La subtransmisión 1 está limitada a una resolución baja. Muchas cámaras Hikvision admiten subtransmisiones adicionales que deben habilitarse en la configuración de la cámara. Se recomienda comprobar y utilizar dichas transmisiones si están disponibles." + } + } + }, + "title": "Añadir cámara", + "description": "Siga los siguientes pasos para agregar una nueva cámara a su instalación de Frigate.", + "steps": { + "nameAndConnection": "Nombre y conexión", + "probeOrSnapshot": "Sonda de prueba o hacer instantánea", + "streamConfiguration": "Configuración de transmisión", + "validationAndTesting": "Validación y pruebas" + }, + "save": { + "success": "La nueva cámara {{cameraName}} se guardó correctamente.", + "failure": "Error al guardar {{cameraName}}." + }, + "testResultLabels": { + "resolution": "Resolución", + "video": "Video", + "audio": "Audio", + "fps": "FPS" + }, + "commonErrors": { + "noUrl": "Proporcione una URL de transmisión válida", + "testFailed": "Prueba de transmisión fallida: {{error}}" + } + }, + "cameraManagement": { + "title": "Administrar cámaras", + "addCamera": "Añadir nueva cámara", + "editCamera": "Editar cámara:", + "selectCamera": "Seleccione una cámara", + "backToSettings": "Volver a configuración de la cámara", + "streams": { + "title": "Habilitar/deshabilitar cámaras", + "desc": "Desactiva temporalmente una cámara hasta que Frigate se reinicie. Desactivar una cámara detiene por completo el procesamiento de las transmisiones de Frigate. La detección, la grabación y la depuración no estarán disponibles.{{label}}?",
+ "ask_an": "Kas see objekt on {{label}}?",
+ "ask_full": "Kas see objekt on {{untranslatedLabel}} ({{translatedLabel}})?",
+ "label": "Kinnita see silt Frigate+ teenuse jaoks"
+ }
+ },
+ "submitToPlus": {
+ "label": "Saada teenusesse Frigate+",
+ "desc": "Objektid asukohtades, mida sa tahad vältida, pole valepositiivsed. Kui sa neid sellistena saadad teenusele, siis see ainult ajab tehisaru mudeli sassi."
+ }
+ }
+ },
+ "export": {
+ "time": {
+ "fromTimeline": "Vali ajajoonelt",
+ "lastHour_one": "Viimase tunni jooksul",
+ "lastHour_other": "Viimase {{count}} tunni jooksul",
+ "custom": "Sinu valitud ajavahemik",
+ "start": {
+ "title": "Algusaeg",
+ "label": "Vali algusaeg"
+ },
+ "end": {
+ "title": "Lõpuaeg",
+ "label": "Vali lõpuaeg"
+ }
+ },
+ "name": {
+ "placeholder": "Sisesta ekspordifaili nimi"
+ },
+ "select": "Vali",
+ "export": "Ekspordi",
+ "selectOrExport": "Vali või ekspordi",
+ "toast": {
+ "success": "Eksportimise käivitamine õnnestus. Faili leiad eksportimise lehelt.",
+ "view": "Vaata",
+ "error": {
+ "failed": "Eksportimise käivitamine ei õnnestunud: {{error}}",
+ "endTimeMustAfterStartTime": "Ajavahemiku lõpp peab olema peale algust",
+ "noVaildTimeSelected": "Ühtegi kehtivat ajavahemikku pole valitud"
+ }
+ },
+ "fromTimeline": {
+ "saveExport": "Salvesta eksporditud sisu",
+ "previewExport": "Eksporditud sisu eelvaade"
+ }
+ },
+ "streaming": {
+ "label": "Voogedastus",
+ "restreaming": {
+ "disabled": "Voogedastuse kordus pole selle kaamera puhul kasutatav.",
+ "desc": {
+ "title": "Kui tahad selle kaameraga kasutada täiendavaid otseeetri ja helivõimalusi, siis seadista go2rtc."
+ }
+ },
+ "debugView": "Veaotsinguvaade",
+ "showStats": {
+ "label": "Näita voogedastuse statistikat",
+ "desc": "Lülita see eelistus sisse, kui soovid kaamerapildi ülekattena näha voogedastuse statistikat."
+ }
+ },
+ "recording": {
+ "button": {
+ "export": "Ekspordi",
+ "markAsReviewed": "Märgi ülevaadatuks",
+ "markAsUnreviewed": "Märgi mitteülevaadatuks",
+ "deleteNow": "Kustuta kohe"
+ },
+ "confirmDelete": {
+ "title": "Kinnita kustutamine",
+ "desc": {
+ "selected": "Kas sa oled kindel et soovid selle kõik ülevaadatava objektiga seotud kirjed kustutada?detect-tüüpi voogedastusest pole tulnud ühtegi kaadrit. Täpsemat teavet leiad vealogidest"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "Kaadri saatmine Frigate+ teenusesse õnnestus"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "Kaadri saatmine Frigate+ teenusesse ei õnnestunud"
+ }
+ }
+}
diff --git a/web/public/locales/et/objects.json b/web/public/locales/et/objects.json
new file mode 100644
index 000000000..19830deaf
--- /dev/null
+++ b/web/public/locales/et/objects.json
@@ -0,0 +1,120 @@
+{
+ "person": "Inimene",
+ "bicycle": "Jalgratas",
+ "car": "Auto",
+ "motorcycle": "Mootorratas",
+ "airplane": "Lennuk",
+ "bus": "Buss",
+ "train": "Rong",
+ "boat": "Väike laev",
+ "traffic_light": "Valgusfoor",
+ "fire_hydrant": "Tuletõrjehüdrant",
+ "street_sign": "Liiklusmärk",
+ "stop_sign": "Stoppmärk",
+ "parking_meter": "Parkimispiletite automaat",
+ "bench": "Istepink",
+ "bird": "Lind",
+ "cat": "Kass",
+ "dog": "Koer",
+ "horse": "Hobune",
+ "sheep": "Lammas",
+ "cow": "Lehm",
+ "elephant": "Elevant",
+ "bear": "Karu",
+ "zebra": "Sebra",
+ "giraffe": "Kaelkirjak",
+ "hat": "Müts",
+ "backpack": "Seljakott",
+ "umbrella": "Vihmavari",
+ "shoe": "King",
+ "eye_glasses": "Prillid",
+ "handbag": "Käekott",
+ "tie": "Lips",
+ "suitcase": "Kohver",
+ "frisbee": "Lendav taldrik",
+ "skis": "Suusad",
+ "snowboard": "Lumelaud",
+ "sports_ball": "Pall",
+ "kite": "Tuulelohe",
+ "baseball_bat": "Pesapallikurikas",
+ "baseball_glove": "Pesapallikinnas",
+ "skateboard": "Rula",
+ "surfboard": "Surfilaud",
+ "tennis_racket": "Tennisereket",
+ "animal": "Loom",
+ "bottle": "Pudel",
+ "plate": "Taldrik",
+ "wine_glass": "Veiniklaas",
+ "cup": "Kruus",
+ "fork": "Kahvel",
+ "knife": "Nuga",
+ "spoon": "Lusikas",
+ "bowl": "Kauss",
+ "banana": "Banaan",
+ "apple": "Õun",
+ "sandwich": "Võileib",
+ "orange": "Apelsin",
+ "broccoli": "Spargelkapsas",
+ "carrot": "Porgand",
+ "hot_dog": "Viinerisai",
+ "pizza": "Pitsa",
+ "donut": "Sõõrik",
+ "cake": "Kook",
+ "chair": "Tool",
+ "couch": "Kušett",
+ "potted_plant": "Potilill",
+ "bed": "Voodi",
+ "mirror": "Peegel",
+ "dining_table": "Söögilaud",
+ "window": "Aken",
+ "desk": "Kirjutuslaud",
+ "toilet": "Tualett",
+ "door": "Uks",
+ "tv": "Teler",
+ "laptop": "Sülearvuti",
+ "mouse": "Hiir",
+ "remote": "Kaugjuhtimispult",
+ "keyboard": "Klahvistik",
+ "cell_phone": "Mobiiltelefon",
+ "microwave": "Mikrolaineahi",
+ "oven": "Ahi",
+ "toaster": "Röster",
+ "sink": "Kraanikauss",
+ "refrigerator": "Külmkapp",
+ "blender": "Kannmikser",
+ "book": "Raamat",
+ "clock": "Kell",
+ "vase": "Vaas",
+ "scissors": "Käärid",
+ "teddy_bear": "Mängukaru",
+ "hair_dryer": "Föön",
+ "toothbrush": "Hambahari",
+ "hair_brush": "Juuksehari",
+ "vehicle": "Sõiduk",
+ "squirrel": "Orav",
+ "deer": "Hirv",
+ "bark": "Puukoor",
+ "fox": "Rebane",
+ "goat": "Kits",
+ "rabbit": "Jänes",
+ "raccoon": "Pesukaru",
+ "robot_lawnmower": "Robotmuruniiduk",
+ "waste_bin": "Prügikast",
+ "on_demand": "Nõudmisel",
+ "face": "Nägu",
+ "license_plate": "Sõiduki numbrimärk",
+ "package": "Pakett",
+ "bbq_grill": "Väligrill",
+ "amazon": "Amazoni sõiduk",
+ "usps": "USPS-i sõiduk",
+ "ups": "UPS-i sõiduk",
+ "fedex": "FedExi sõiduk",
+ "dhl": "DHL-i sõiduk",
+ "an_post": "An Posti sõiduk",
+ "purolator": "Purolatori sõiduk",
+ "postnl": "PostNL-i sõiduk",
+ "nzpost": "NZPost-i sõiduk",
+ "postnord": "PostNordi sõiduk",
+ "gls": "GLS-i sõiduk",
+ "dpd": "DPD sõiduk"
+}
diff --git a/web/public/locales/et/views/classificationModel.json b/web/public/locales/et/views/classificationModel.json
new file mode 100644
index 000000000..93db04cba
--- /dev/null
+++ b/web/public/locales/et/views/classificationModel.json
@@ -0,0 +1,47 @@
+{
+ "toast": {
+ "success": {
+ "deletedModel_one": "{{count}} mudeli kustutamine õnnestus",
+ "deletedModel_other": "{{count}} mudeli kustutamine õnnestus"
+ }
+ },
+ "documentTitle": "Klassifitseerimise mudelid - Frigate",
+ "details": {
+ "scoreInfo": "Skoor näitab selle objekti kõigi tuvastuste keskmist klassifitseerimise usaldusväärsust.",
+ "none": "Puudub",
+ "unknown": "Pole teada"
+ },
+ "button": {
+ "deleteClassificationAttempts": "Kustuta klassifitseerimispildid",
+ "renameCategory": "Muuda klassi nimi",
+ "deleteCategory": "Kustuta klass",
+ "deleteImages": "Kustuta pildid",
+ "addClassification": "Lisa klassifikatsioon",
+ "deleteModels": "Kustuta mudelid",
+ "editModel": "Muuda mudelit"
+ },
+ "description": {
+ "invalidName": "Vigane nimi. Nimed võivad sisaldada ainult tähti, numbreid, tühikuid, ülakomasid, alakriipse ja sidekriipse."
+ },
+ "deleteModel": {
+ "desc_one": "Kas oled kindel, et soovid kustutada {{count}} mudeli? Järgnevaga kustuvad jäädavalt kõik seotud andmed, sealhulgas pildid ja koolitusandmed. Seda tegevust ei saa tagasi pöörata.",
+ "desc_other": "Kas oled kindel, et soovid kustutada {{count}} mudelit? Järgnevaga kustuvad jäädavalt kõik seotud andmed, sealhulgas pildid ja koolitusandmed. Seda tegevust ei saa tagasi pöörata."
+ },
+ "deleteDatasetImages": {
+ "desc_one": "Kas oled kindel, et soovid kustutada {{count}} pildi {{dataset}} andmekogust? Seda tegevust ei saa tagasi pöörata ja hiljem on vaja mudelit uuesti koolitada.",
+ "desc_other": "Kas oled kindel, et soovid kustutada {{count}} pilti {{dataset}} andmekogust? Seda tegevust ei saa tagasi pöörata ja hiljem on vaja mudelit uuesti koolitada."
+ },
+ "deleteTrainImages": {
+ "desc_one": "Kas oled kindel, et soovid kustutada {{count}} pildi? Seda tegevust ei saa tagasi pöörata.",
+ "desc_other": "Kas oled kindel, et soovid kustutada {{count}} pilti? Seda tegevust ei saa tagasi pöörata."
+ },
+ "wizard": {
+ "step3": {
+ "allImagesRequired_one": "Palun klassifitseeri kõik pildid. Jäänud on veel {{count}} pilt.",
+ "allImagesRequired_other": "Palun klassifitseeri kõik pildid. Jäänud on veel {{count}} pilti."
+ }
+ },
+ "tooltip": {
+ "trainingInProgress": "Mudel on parasjagu õppimas"
+ }
+}
diff --git a/web/public/locales/et/views/configEditor.json b/web/public/locales/et/views/configEditor.json
new file mode 100644
index 000000000..56371cd04
--- /dev/null
+++ b/web/public/locales/et/views/configEditor.json
@@ -0,0 +1,18 @@
+{
+ "toast": {
+ "error": {
+ "savingError": "Viga seadistuse salvestamisel"
+ },
+ "success": {
+ "copyToClipboard": "Seadistused on kopeeritud lõikelauale."
+ }
+ },
+ "documentTitle": "Seadistuste haldus - Frigate",
+ "safeConfigEditor": "Seadistuste haldus (ohutusrežiim)",
+ "configEditor": "Seadistuste haldus",
+ "safeModeDescription": "Seadistuste vea tõttu on Frigate hetkel ohutusrežiimis.",
+ "copyConfig": "Kopeeri seadistused",
+ "saveAndRestart": "Salvesta ja käivita uuesti",
+ "saveOnly": "Vaid salvesta",
+ "confirm": "Kas väljud ilma salvestamata?"
+}
diff --git a/web/public/locales/et/views/events.json b/web/public/locales/et/views/events.json
new file mode 100644
index 000000000..75e4a3d5c
--- /dev/null
+++ b/web/public/locales/et/views/events.json
@@ -0,0 +1,65 @@
+{
+ "alerts": "Häired",
+ "allCameras": "Kõik kaamerad",
+ "detail": {
+ "settings": "Üksikasjaliku vaate seadistused",
+ "label": "Üksikasjad",
+ "noDataFound": "Ülevaatamiseks pole üksikasjalikke andmeid",
+ "aria": "Lülita üksikasjalik vaade sisse/välja",
+ "trackedObject_one": "{{count}} objekt",
+ "trackedObject_other": "{{count}} objekti",
+ "noObjectDetailData": "Objekti üksikasjalikke andmeid pole saadaval.",
+ "alwaysExpandActive": {
+ "title": "Alati laienda aktiivse kirje andmeid",
+ "desc": "Kui vähegi saadaval, siis alati laienda aktiivse ülevaatamisel kirje andmeid."
+ }
+ },
+ "detections": "Tuvastamise tulemused",
+ "motion": {
+ "label": "Liikumine",
+ "only": "Vaid liikumine"
+ },
+ "empty": {
+ "alert": "Ülevaatamiseks ei leidu ühtegi häiret",
+ "detection": "Ülevaatamiseks ei leidu ühtegi tuvastamist",
+ "motion": "Liikumise andmeid ei leidu",
+ "recordingsDisabled": {
+ "title": "Salvestamine peab olema sisse lülitatud",
+ "description": "Objekte saad määrata ülevaadatamiseks vaid siis, kui selle kaamera puhul on salvestamine lülitatud sisse."
+ }
+ },
+ "select_all": "Kõik",
+ "camera": "Kaamera",
+ "detected": "tuvastatud",
+ "normalActivity": "Tavaline",
+ "needsReview": "Vajab ülevaatamist",
+ "securityConcern": "Võib olla turvaprobleem",
+ "timeline": "Ajajoon",
+ "timeline.aria": "Vali ajajoon",
+ "zoomIn": "Suumi sisse",
+ "zoomOut": "Suumi välja",
+ "events": {
+ "label": "Sündmused",
+ "aria": "Vali sündmused",
+ "noFoundForTimePeriod": "Selle ajavahemiku kohta ei leidu sündmusi."
+ },
+ "selected_one": "{{count}} valitud",
+ "selected_other": "{{count}} valitud",
+ "markAsReviewed": "Märgi ülevaadatuks",
+ "markTheseItemsAsReviewed": "Märgi need kirjed ülevaadatuks",
+ "newReviewItems": {
+ "label": "Vaata uusi ülevaatamiseks mõeldud kirjeid",
+ "button": "Uued ülevaatamiseks mõeldud kirjed"
+ },
+ "documentTitle": "Ülevaatamine - Frigate",
+ "recordings": {
+ "documentTitle": "Salvestised - Frigate"
+ },
+ "calendarFilter": {
+ "last24Hours": "Viimased 24 tundi"
+ },
+ "objectTrack": {
+ "clickToSeek": "Klõpsa siia ajapunkti kerimiseks",
+ "trackedPoint": "Jälgitav punkt"
+ }
+}
diff --git a/web/public/locales/et/views/explore.json b/web/public/locales/et/views/explore.json
new file mode 100644
index 000000000..1676f3ccd
--- /dev/null
+++ b/web/public/locales/et/views/explore.json
@@ -0,0 +1,87 @@
+{
+ "trackedObjectsCount_one": "{{count}} jälgitav objekt ",
+ "trackedObjectsCount_other": "{{count}} jälgitavat objekti ",
+ "fetchingTrackedObjectsFailed": "Viga jälgitavate objektide laadimisel: {{errorMessage}}",
+ "noTrackedObjects": "Ühtegi jälgitavat objekti ei leidunud",
+ "itemMenu": {
+ "findSimilar": {
+ "aria": "Otsi sarnaseid jälgitavaid objekte"
+ },
+ "downloadSnapshot": {
+ "label": "Laadi hetkvõte alla",
+ "aria": "Laadi hetkvõte alla"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Laadi puhas hetkvõte alla",
+ "aria": "Laadi puhas hetkvõte alla"
+ }
+ },
+ "trackingDetails": {
+ "annotationSettings": {
+ "showAllZones": {
+ "title": "Näita kõiki tsoone",
+ "desc": "Kui objekt on sisenenud tsooni, siis alati näida tsooni märgistust."
+ }
+ },
+ "lifecycleItemDesc": {
+ "attribute": {
+ "other": "{{label}} on tuvastatud kui {{attribute}}"
+ },
+ "stationary": "{{label}} jäi paigale",
+ "active": "{{label}} muutus aktiivseks",
+ "entered_zone": "{{label}} sisenes tsooni {{zones}}",
+ "visible": "{{label}} on tuvastatud",
+ "header": {
+ "zones": "Tsoonid",
+ "ratio": "Suhtarv",
+ "area": "Ala",
+ "score": "Punktiskoor"
+ }
+ },
+ "title": "Jälgimise üksikasjad",
+ "noImageFound": "Selle ajatempli kohta ei leidu pilti.",
+ "createObjectMask": "Loo objektimask",
+ "carousel": {
+ "previous": "Eelmine slaid",
+ "next": "Järgmine slaid"
+ }
+ },
+ "documentTitle": "Avasta - Frigate",
+ "generativeAI": "Generatiivne tehisaru",
+ "exploreMore": "Avasta rohkem {{label}}-tüüpi objekte",
+ "exploreIsUnavailable": {
+ "embeddingsReindexing": {
+ "step": {
+ "thumbnailsEmbedded": "Pisipildid on lõimitud: ",
+ "descriptionsEmbedded": "Kirjeldused on lõimitud: ",
+ "trackedObjectsProcessed": "Jälgitud objektid on töödeldud: "
+ },
+ "startingUp": "Käivitun…",
+ "estimatedTime": "Hinnanguliselt jäänud aega:",
+ "finishingShortly": "Lõpetan õige pea"
+ }
+ },
+ "type": {
+ "details": "üksikasjad",
+ "thumbnail": "pisipilt",
+ "snapshot": "hetkvõte",
+ "video": "video",
+ "tracking_details": "jälgimise üksikasjad"
+ },
+ "details": {
+ "item": {
+ "tips": {
+ "mismatch_one": "Tuvastasin {{count}} võõra objekti ja need on lisatud ülevaatamiseks. Need objektid kas ei ole piisavad häire või tuvastamise jaoks, aga ka võivad juba olla eemaldatud või kustutatud.",
+ "mismatch_other": "Tuvastasin {{count}} võõrast objekti ja need on lisatud ülevaatamiseks. Need objektid kas ei ole piisavad häire või tuvastamise jaoks, aga ka võivad juba olla eemaldatud või kustutatud."
+ },
+ "title": "Vaata objekti üksikasju",
+ "desc": "Vaata objekti üksikasju"
+ },
+ "snapshotScore": {
+ "label": "Hetkvõttete punktiskoor"
+ },
+ "regenerateFromSnapshot": "Loo uuesti hetkvõttest",
+ "timestamp": "Ajatampel"
+ },
+ "trackedObjectDetails": "Jälgitava objekti üksikasjad"
+}
diff --git a/web/public/locales/et/views/exports.json b/web/public/locales/et/views/exports.json
new file mode 100644
index 000000000..56814537e
--- /dev/null
+++ b/web/public/locales/et/views/exports.json
@@ -0,0 +1,23 @@
+{
+ "documentTitle": "Eksport Frigate'ist",
+ "search": "Otsi",
+ "noExports": "Eksporditud sisu ei leidu",
+ "deleteExport": "Kustuta eksporditud sisu",
+ "deleteExport.desc": "Kas sa oled kindel et soovid „{{exportName}}“ kustutada?",
+ "editExport": {
+ "title": "Muuda eksporditud sisu nime",
+ "desc": "Sisesta eksporditud sisu jaoks uus nimi.",
+ "saveExport": "Salvesta eksporditud sisu"
+ },
+ "tooltip": {
+ "shareExport": "Jaga eksporditud sisu",
+ "downloadVideo": "Laadi video alla",
+ "editName": "Muuda nime",
+ "deleteExport": "Kustuta eksporditud sisu"
+ },
+ "toast": {
+ "error": {
+ "renameExportFailed": "Eksporditud sisu nime muutmine ei õnnestunud: {{errorMessage}}"
+ }
+ }
+}
diff --git a/web/public/locales/et/views/faceLibrary.json b/web/public/locales/et/views/faceLibrary.json
new file mode 100644
index 000000000..42c795a06
--- /dev/null
+++ b/web/public/locales/et/views/faceLibrary.json
@@ -0,0 +1,38 @@
+{
+ "button": {
+ "uploadImage": "Laadi pilt üles"
+ },
+ "collections": "Kogumikud",
+ "description": {
+ "placeholder": "Sisesta nimi selle kogumiku jaoks",
+ "invalidName": "Vigane nimi. Nimed võivad sisaldada ainult tähti, numbreid, tühikuid, ülakomasid, alakriipse ja sidekriipse.",
+ "addFace": "Laadides üles oma esimese pildi saad lisada uue kogumiku Näoteeki."
+ },
+ "documentTitle": "Näoteek - Frigate",
+ "createFaceLibrary": {
+ "new": "Lisa uus nägu"
+ },
+ "deleteFaceLibrary": {
+ "title": "Kustuta nimi"
+ },
+ "toast": {
+ "error": {
+ "addFaceLibraryFailed": "Näo sidumine nimega ei õnnestunud: {{errorMessage}}"
+ },
+ "success": {
+ "addFaceLibrary": "Lisamine Näoteeki õnnestus: {{name}}!",
+ "deletedFace_one": "{{count}} näo kustutamine õnnestus.",
+ "deletedFace_other": "{{count}} näo kustutamine õnnestus.",
+ "deletedName_one": "{{count}} näo kustutamine õnnestus.",
+ "deletedName_other": "{{count}} näo kustutamine õnnestus."
+ }
+ },
+ "deleteFaceAttempts": {
+ "desc_one": "Kas oled kindel, et soovid kustutada {{count}} näo? Seda tegevust ei saa tagasi pöörata.",
+ "desc_other": "Kas oled kindel, et soovid kustutada {{count}} nägu? Seda tegevust ei saa tagasi pöörata."
+ },
+ "details": {
+ "timestamp": "Ajatampel",
+ "unknown": "Pole teada"
+ }
+}
diff --git a/web/public/locales/et/views/live.json b/web/public/locales/et/views/live.json
new file mode 100644
index 000000000..11b5abaaa
--- /dev/null
+++ b/web/public/locales/et/views/live.json
@@ -0,0 +1,158 @@
+{
+ "muteCameras": {
+ "enable": "Summuta kõik kaamerad",
+ "disable": "Lõpeta kõikide kaamerate summutamine"
+ },
+ "streamingSettings": "Voogedastuse seadistused",
+ "cameraSettings": {
+ "title": "Seadistused: {{camera}}",
+ "cameraEnabled": "Kaamera on kasutusel",
+ "objectDetection": "Objektide tuvastamine",
+ "audioDetection": "Heli tuvastus",
+ "transcription": "Heli üleskirjutus",
+ "snapshots": "Hetkvõtted",
+ "autotracking": "Automaatne jälgimine"
+ },
+ "documentTitle": "Otseülekanne - Frigate",
+ "documentTitle.withCamera": "{{camera}} - Otseülekanne - Frigate",
+ "lowBandwidthMode": "Väikese ribalaiusega režiim",
+ "twoWayTalk": {
+ "enable": "Lülita kahepoolne kõneside sisse",
+ "disable": "Lülita kahepoolne kõneside välja"
+ },
+ "cameraAudio": {
+ "enable": "Lülita kaamera heli sisse",
+ "disable": "Lülita kaamera heli välja"
+ },
+ "ptz": {
+ "move": {
+ "clickMove": {
+ "label": "Kaamerapildi joondamiseks keskele klõpsa kaadris",
+ "enable": "Kasuta klõpsamisega teisaldamist",
+ "disable": "Ära kasuta klõpsamisega teisaldamist"
+ },
+ "left": {
+ "label": "Pööra liigutatavat kaamerat vasakule"
+ },
+ "up": {
+ "label": "Pööra liigutatavat kaamerat üles"
+ },
+ "down": {
+ "label": "Pööra liigutatavat kaamerat alla"
+ },
+ "right": {
+ "label": "Pööra liigutatavat kaamerat paremale"
+ }
+ },
+ "zoom": {
+ "in": {
+ "label": "Suumi liigutatavat kaamerat sisse"
+ },
+ "out": {
+ "label": "Suumi liigutatavat kaamerat välja"
+ }
+ },
+ "focus": {
+ "in": {
+ "label": "Fookusta liigutatavat kaamerat sisse"
+ },
+ "out": {
+ "label": "Fookusta liigutatavat kaamerat välja"
+ }
+ },
+ "presets": "Liigutatava kaamera eelseadistused",
+ "frame": {
+ "center": {
+ "label": "Klõpsa kaadrit liigutatava kaamera pildi sättimiseks keskele"
+ }
+ }
+ },
+ "camera": {
+ "enable": "Lülita kaamera sisse",
+ "disable": "Lülita kaamera välja"
+ },
+ "detect": {
+ "enable": "Lülita tuvastamine sisse",
+ "disable": "Lülita tuvastamine välja"
+ },
+ "recording": {
+ "enable": "Lülita salvestamine sisse",
+ "disable": "Lülita salvestamine välja"
+ },
+ "snapshots": {
+ "enable": "Lülita hetkvõtted sisse",
+ "disable": "Lülita hetkvõtted välja"
+ },
+ "streamStats": {
+ "enable": "Näita voogedastuse statistikat",
+ "disable": "Peida voogedastuse statistika"
+ },
+ "stream": {
+ "twoWayTalk": {
+ "available": "Kahepoolne kõneside on selle voogedastuse puhul saadaval",
+ "unavailable": "Kahepoolne kõneside pole selle voogedastuse puhul saadaval",
+ "tips": "Sinu seadme peab seda funktsionaalsust toetama ja WebRTC peab olema kahepoolse kõneside jaoks seadistatud."
+ },
+ "playInBackground": {
+ "label": "Esita taustal",
+ "tips": "Selle eelistusega saad määrata, et voogedastus jääb tööle ka siis, kui meesiaesitaja on suletud."
+ },
+ "audio": {
+ "available": "Selles voogedastuses on heliriba saadaval",
+ "unavailable": "Selles voogedastuses pole heliriba saadaval"
+ }
+ },
+ "notifications": "Teavitused",
+ "audio": "Heli",
+ "snapshot": {
+ "takeSnapshot": "Laadi hetkvõte alla",
+ "noVideoSource": "Hetkvõtte tegemiseks pole saadaval ühtegi videoallikat.",
+ "captureFailed": "Hetkvõtte jäädvustamine ei õnnestunud.",
+ "downloadStarted": "Hetkvõtte allalaadimine algas."
+ },
+ "audioDetect": {
+ "enable": "Lülita helituvastus sisse",
+ "disable": "Lülita helituvastus välja"
+ },
+ "transcription": {
+ "enable": "Lülita reaalajas heli üleskirjutus sisse",
+ "disable": "Lülita reaalajas heli üleskirjutus välja"
+ },
+ "autotracking": {
+ "enable": "Lülita automaatne jälgimine sisse",
+ "disable": "Lülita automaatne jälgimine välja"
+ },
+ "manualRecording": {
+ "title": "Nõudmisel",
+ "playInBackground": {
+ "label": "Esita taustal",
+ "desc": "Kasuta seda valikut, kui tahad voogedastuse jätkumist ka siis, kui pildivaade on peidetud."
+ }
+ },
+ "noCameras": {
+ "buttonText": "Lisa kaamera",
+ "restricted": {
+ "title": "Ühtegi kaamerat pole saadaval",
+ "description": "Sul pole õigust ühegi selle grupi kaamera vaatamiseks."
+ },
+ "title": "Ühtegi kaamerat pole seadistatud",
+ "description": "Alustamiseks ühenda mõni kaamera Frigate'iga."
+ },
+ "effectiveRetainMode": {
+ "modes": {
+ "active_objects": "Aktiivsed objektid",
+ "all": "Kõik",
+ "motion": "Liikumine"
+ }
+ },
+ "editLayout": {
+ "label": "Muuda paigutust",
+ "group": {
+ "label": "Muuda kaameragruppi"
+ },
+ "exitEdit": "Välju muutmisest"
+ },
+ "history": {
+ "label": "Näita varasemat sisu"
+ }
+}
diff --git a/web/public/locales/et/views/recording.json b/web/public/locales/et/views/recording.json
new file mode 100644
index 000000000..57ed97509
--- /dev/null
+++ b/web/public/locales/et/views/recording.json
@@ -0,0 +1,12 @@
+{
+ "export": "Ekspordi",
+ "calendar": "Kalender",
+ "filter": "Filter",
+ "filters": "Filtrid",
+ "toast": {
+ "error": {
+ "noValidTimeSelected": "Ühtegi kehtivat ajavahemikku pole valitud",
+ "endTimeMustAfterStartTime": "Ajavahemiku lõpp peab olema peale algust"
+ }
+ }
+}
diff --git a/web/public/locales/et/views/search.json b/web/public/locales/et/views/search.json
new file mode 100644
index 000000000..52b917d22
--- /dev/null
+++ b/web/public/locales/et/views/search.json
@@ -0,0 +1,23 @@
+{
+ "placeholder": {
+ "search": "Otsi…"
+ },
+ "search": "Otsi",
+ "savedSearches": "Salvestatud otsingud",
+ "searchFor": "Otsi: {{inputValue}}",
+ "button": {
+ "clear": "Tühjenda otsing",
+ "save": "Salvesta otsing",
+ "delete": "Kustuta salvestatud otsing",
+ "filterInformation": "Filtri teave"
+ },
+ "filter": {
+ "label": {
+ "has_snapshot": "Leidub hetkvõte",
+ "cameras": "Kaamerad",
+ "labels": "Sildid",
+ "zones": "Tsoonid",
+ "sub_labels": "Alamsildid"
+ }
+ }
+}
diff --git a/web/public/locales/et/views/settings.json b/web/public/locales/et/views/settings.json
new file mode 100644
index 000000000..ce100a719
--- /dev/null
+++ b/web/public/locales/et/views/settings.json
@@ -0,0 +1,423 @@
+{
+ "cameraWizard": {
+ "step1": {
+ "password": "Salasõna",
+ "passwordPlaceholder": "Valikuline",
+ "customUrlPlaceholder": "rtsp://kasutajanimi:salasõna@host:port/asukoht",
+ "connectionSettings": "Ühenduse seadistused",
+ "port": "Port",
+ "username": "Kasutajanimi",
+ "usernamePlaceholder": "Valikuline"
+ },
+ "step3": {
+ "streamUrlPlaceholder": "rtsp://kasutajanimi:salasõna@host:port/asukoht",
+ "url": "Võrguaadress",
+ "resolution": "Resolutsioon",
+ "quality": "Kvaliteet",
+ "roles": "Rollid",
+ "roleLabels": {
+ "record": "Salvestamine",
+ "audio": "Heliriba"
+ },
+ "connected": "Ühendatud",
+ "featuresTitle": "Funktsionaalsused"
+ },
+ "steps": {
+ "probeOrSnapshot": "Võta proov või tee hetkvõte"
+ },
+ "step2": {
+ "testing": {
+ "fetchingSnapshot": "Laadin kaamera hetkvõtet alla..."
+ },
+ "retry": "Proovi uuesti",
+ "manufacturer": "Tootja",
+ "model": "Mudel",
+ "firmware": "Püsivara",
+ "profiles": "Profiilid",
+ "presets": "Eelseadistused",
+ "useCandidate": "Kasuta",
+ "uriCopy": "Kopeeri",
+ "connected": "Ühendatud"
+ },
+ "testResultLabels": {
+ "resolution": "Resolutsioon",
+ "video": "Video",
+ "audio": "Heliriba",
+ "fps": "Kaadrisagedus"
+ },
+ "step4": {
+ "reload": "Laadi uuesti",
+ "connecting": "Ühendan…",
+ "valid": "Kehtiv",
+ "failed": "Ebaõnnestunud",
+ "connectStream": "Ühenda",
+ "connectingStream": "Ühendan",
+ "disconnectStream": "Katkesta ühendus",
+ "roles": "Rollid",
+ "none": "Määramata",
+ "error": "Viga"
+ }
+ },
+ "users": {
+ "updatePassword": "Lähtesta salasõna",
+ "toast": {
+ "success": {
+ "updatePassword": "Salasõna muutmine õnnestus."
+ },
+ "error": {
+ "setPasswordFailed": "Salasõna salvestamine ei õnnestunud: {{errorMessage}}"
+ }
+ },
+ "table": {
+ "password": "Lähtesta salasõna",
+ "username": "Kasutajanimi",
+ "actions": "Tegevused",
+ "role": "Roll"
+ },
+ "dialog": {
+ "form": {
+ "password": {
+ "title": "Salasõna",
+ "placeholder": "Sisesta salasõna",
+ "confirm": {
+ "title": "Korda salasõna",
+ "placeholder": "Korda salasõna"
+ },
+ "strength": {
+ "title": "Salasõna tugevus: ",
+ "weak": "Nõrk",
+ "medium": "Keskmime",
+ "strong": "Tugev",
+ "veryStrong": "Väga tugev"
+ },
+ "match": "Salasõnad klapivad omavahel",
+ "notMatch": "Salasõnad ei klapi omavahel",
+ "show": "Näita salasõna",
+ "hide": "Peida salasõna",
+ "requirements": {
+ "title": "Salasõna reeglid:",
+ "length": "Vähemalt 12 tähemärki",
+ "uppercase": "Vähemalt üks suurtäht",
+ "digit": "Vähemalt üks number",
+ "special": "Vähemalt üks erimärk (!@#$%^&*(),.?\":{}|<>)"
+ }
+ },
+ "newPassword": {
+ "title": "Uus salasõna",
+ "placeholder": "Sisesta uus salasõna",
+ "confirm": {
+ "placeholder": "Sisesta uus salasõna uuesti"
+ }
+ },
+ "passwordIsRequired": "Salasõna on vajalik",
+ "currentPassword": {
+ "title": "Senine salasõna",
+ "placeholder": "Sisesta oma senine salasõna"
+ },
+ "user": {
+ "title": "Kasutajanimi"
+ }
+ },
+ "createUser": {
+ "confirmPassword": "Palun kinnita oma uus salasõna"
+ },
+ "passwordSetting": {
+ "cannotBeEmpty": "Salasõna ei või jääda tühjaks",
+ "doNotMatch": "Salasõnad ei klapi omavahel",
+ "updatePassword": "Muuda kasutaja {{username}} salasõna",
+ "setPassword": "Sisesta salasõna",
+ "desc": "Selle kasutajakonto turvalisuse tagamiseks lisa tugev salasõna.",
+ "currentPasswordRequired": "Senine salasõna on vajalik",
+ "incorrectCurrentPassword": "Senine salasõna pole õige",
+ "passwordVerificationFailed": "Salasõna kontrollimine ei õnnestunud"
+ },
+ "changeRole": {
+ "roleInfo": {
+ "admin": "Peakasutaja",
+ "viewer": "Vaataja"
+ }
+ }
+ },
+ "title": "Kasutajad"
+ },
+ "debug": {
+ "boundingBoxes": {
+ "desc": "Näita jälgitavate objektide ümber märgiskaste"
+ },
+ "title": "Silumine ja veaotsing",
+ "debugging": "Veaotsing ja silumine",
+ "audio": {
+ "title": "Heliriba",
+ "score": "punktiskoor"
+ },
+ "timestamp": {
+ "title": "Ajatempel"
+ },
+ "zones": {
+ "title": "Tsoonid"
+ },
+ "regions": {
+ "title": "Alad"
+ },
+ "paths": {
+ "title": "Asukohad"
+ },
+ "objectShapeFilterDrawing": {
+ "score": "Punktiskoor",
+ "ratio": "Suhtarv",
+ "area": "Ala"
+ }
+ },
+ "documentTitle": {
+ "default": "Seadistused - Frigate",
+ "authentication": "Autentimise seadistused - Frigate",
+ "cameraReview": "Kaamerate kordusvaatuste seadistused - Frigate",
+ "general": "Kasutajaliidese seadistused - Frigate",
+ "frigatePlus": "Frigate+ seadistused - Frigate",
+ "notifications": "Teavituste seadistused - Frigate",
+ "cameraManagement": "Kaamerate haldus - Frigate",
+ "masksAndZones": "Maskide ja tsoonide haldus - Frigate",
+ "object": "Silumine ja veaotsing - Frigate"
+ },
+ "general": {
+ "title": "Kasutajaliidese seadistused",
+ "cameraGroupStreaming": {
+ "clearAll": "Kustuta kõik voogedastuse seadistused"
+ },
+ "liveDashboard": {
+ "title": "Töölaud reaalajas",
+ "automaticLiveView": {
+ "label": "Automaatne otseülekande vaade"
+ }
+ },
+ "calendar": {
+ "title": "Kalender",
+ "firstWeekday": {
+ "sunday": "Pühapäev",
+ "monday": "Esmaspäev",
+ "label": "Esimene nädalapäev"
+ }
+ },
+ "storedLayouts": {
+ "title": "Salvestatud paigutused"
+ },
+ "recordingsViewer": {
+ "title": "Salvestuste vaataja"
+ }
+ },
+ "cameraManagement": {
+ "backToSettings": "Tagasi kaameraseadistuste juurde",
+ "cameraConfig": {
+ "enabled": "Kasutusel",
+ "ffmpeg": {
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Rollid"
+ }
+ }
+ },
+ "notification": {
+ "notificationSettings": {
+ "title": "Teavituste seadistused"
+ },
+ "globalSettings": {
+ "title": "Üldseadistused"
+ },
+ "deviceSpecific": "Seadmekohased seadistused",
+ "toast": {
+ "success": {
+ "settingSaved": "Teavituste seadistused on salvestatud."
+ }
+ },
+ "title": "Teavitused",
+ "email": {
+ "title": "E-post"
+ },
+ "cameras": {
+ "title": "Kaamerad"
+ },
+ "suspendTime": {
+ "suspend": "Peata arvuti töö"
+ }
+ },
+ "frigatePlus": {
+ "title": "Frigate+ seadistused",
+ "unsavedChanges": "Frigate+ seadistuste muudatused on salvestamata",
+ "toast": {
+ "success": "Frigate+ seadistuste muudatused on salvestatud. Muudatuste kasutuselevõtmiseks käivita Frigate uuesti."
+ },
+ "snapshotConfig": {
+ "title": "Hetkvõtte seadistused",
+ "table": {
+ "snapshots": "Hetkvõtted",
+ "cleanCopySnapshots": "clean_copy Hetkvõtted",
+ "camera": "Kaamera"
+ }
+ },
+ "modelInfo": {
+ "plusModelType": {
+ "userModel": "Peenhäälestatud"
+ },
+ "cameras": "Kaamerad"
+ }
+ },
+ "masksAndZones": {
+ "zones": {
+ "point_one": "{{count}} punkt",
+ "point_other": "{{count}} punkti",
+ "label": "Tsoonid",
+ "desc": {
+ "documentation": "Dokumentatsioon"
+ },
+ "name": {
+ "title": "Nimi"
+ },
+ "inertia": {
+ "title": "Inerts"
+ },
+ "objects": {
+ "title": "Objektid"
+ }
+ },
+ "motionMasks": {
+ "point_one": "{{count}} punkt",
+ "point_other": "{{count}} punkti",
+ "desc": {
+ "documentation": "Dokumentatsioon"
+ }
+ },
+ "objectMasks": {
+ "point_one": "{{count}} punkt",
+ "point_other": "{{count}} punkti",
+ "desc": {
+ "documentation": "Dokumentatsioon"
+ },
+ "objects": {
+ "title": "Objektid"
+ }
+ }
+ },
+ "roles": {
+ "toast": {
+ "success": {
+ "userRolesUpdated_one": "{{count}} selle rolliga kasutaja on nüüd määratud Vaatajaks, kellel on ligipääs kõikidele kaameratele.",
+ "userRolesUpdated_other": "{{count}} selle rolliga kasutajat on nüüd määratud Vaatajaks, kellel on ligipääs kõikidele kaameratele."
+ }
+ },
+ "table": {
+ "role": "Roll",
+ "cameras": "Kaamerad",
+ "actions": "Tegevused"
+ },
+ "dialog": {
+ "deleteRole": {
+ "deleting": "Kustutan..."
+ },
+ "form": {
+ "cameras": {
+ "title": "Kaamerad"
+ }
+ }
+ }
+ },
+ "menu": {
+ "ui": "Kasutajaliides",
+ "cameraManagement": "Haldus",
+ "masksAndZones": "Maskid ja tsoonid",
+ "triggers": "Päästikud",
+ "debug": "Silumine ja veaotsing",
+ "users": "Kasutajad",
+ "roles": "Rollid",
+ "notifications": "Teavitused",
+ "frigateplus": "Frigate+",
+ "cameraReview": "Ülevaatamine"
+ },
+ "dialog": {
+ "unsavedChanges": {
+ "title": "Sul on salvestamata muudatusi.",
+ "desc": "Kas soovid muudatused enne jätkamist salvestada?"
+ }
+ },
+ "cameraSetting": {
+ "camera": "Kaamera",
+ "noCamera": "Kaamerat pole"
+ },
+ "enrichments": {
+ "semanticSearch": {
+ "reindexNow": {
+ "confirmButton": "Indekseeri uuesti",
+ "label": "Indekseeri uuesti kohe"
+ },
+ "modelSize": {
+ "small": {
+ "title": "väike"
+ },
+ "large": {
+ "title": "suur"
+ }
+ },
+ "title": "Semantiline otsing"
+ },
+ "faceRecognition": {
+ "modelSize": {
+ "small": {
+ "title": "väike"
+ },
+ "large": {
+ "title": "suur"
+ }
+ }
+ },
+ "birdClassification": {
+ "title": "Lindude klassifikatsioon"
+ }
+ },
+ "cameraReview": {
+ "review": {
+ "title": "Ülevaatamine",
+ "alerts": "Hoiatused ",
+ "detections": "Tuvastamise tulemused "
+ }
+ },
+ "motionDetectionTuner": {
+ "Threshold": {
+ "title": "Lävi"
+ }
+ },
+ "triggers": {
+ "documentTitle": "Päästikud",
+ "management": {
+ "title": "Päästikud"
+ },
+ "table": {
+ "name": "Nimi",
+ "type": "Tüüp",
+ "content": "Sisu",
+ "threshold": "Lävi",
+ "actions": "Tegevused",
+ "edit": "Muuda"
+ },
+ "type": {
+ "thumbnail": "Pisipilt",
+ "description": "Kirjeldus"
+ },
+ "dialog": {
+ "form": {
+ "name": {
+ "title": "Nimi"
+ },
+ "type": {
+ "title": "Tüüp"
+ },
+ "content": {
+ "title": "Sisu"
+ },
+ "threshold": {
+ "title": "Lävi"
+ },
+ "actions": {
+ "title": "Tegevused"
+ }
+ }
+ }
+ }
+}
diff --git a/web/public/locales/et/views/system.json b/web/public/locales/et/views/system.json
new file mode 100644
index 000000000..b3bbb33aa
--- /dev/null
+++ b/web/public/locales/et/views/system.json
@@ -0,0 +1,17 @@
+{
+ "documentTitle": {
+ "general": "Üldine statistika - Frigate",
+ "cameras": "Kaamerate statistika - Frigate",
+ "storage": "Andmeruumi statistika - Frigate"
+ },
+ "logs": {
+ "download": {
+ "label": "Laadi logid alla"
+ },
+ "copy": {
+ "label": "Kopeeri lõikelauale",
+ "success": "Logid on kopeeritud lõikelauale"
+ }
+ },
+ "title": "Süsteem"
+}
diff --git a/web/public/locales/fa/audio.json b/web/public/locales/fa/audio.json
index 965460f7f..b3e547006 100644
--- a/web/public/locales/fa/audio.json
+++ b/web/public/locales/fa/audio.json
@@ -23,5 +23,481 @@
"bus": "اتوبوس",
"motorcycle": "موتور سیکلت",
"train": "قطار",
- "bicycle": "دوچرخه"
+ "bicycle": "دوچرخه",
+ "child_singing": "آواز خواندن کودک",
+ "snort": "خرناس",
+ "cough": "سرفه",
+ "throat_clearing": "صاف کردن گلو",
+ "sneeze": "عطسه",
+ "sniff": "بو کشیدن",
+ "run": "دویدن",
+ "synthetic_singing": "آواز مصنوعی",
+ "rapping": "رپخوانی",
+ "humming": "هومخوانی",
+ "sheep": "گوسفند",
+ "groan": "ناله",
+ "grunt": "غرغر",
+ "whistling": "سوت زدن",
+ "breathing": "تنفس",
+ "wheeze": "خِسخِس",
+ "snoring": "خروپف",
+ "gasp": "به نفسنفس افتادن",
+ "pant": "نفسنفسزدن",
+ "shuffle": "پخش تصادفی",
+ "footsteps": "صدای قدمها",
+ "chewing": "جویدن",
+ "biting": "گاز گرفتن",
+ "camera": "دوربین",
+ "gargling": "غرغره کردنغرغره کردن",
+ "stomach_rumble": "قاروقور شکم",
+ "burping": "آروغ زدن",
+ "skateboard": "اسکیتبورد",
+ "yip": "ییپ",
+ "howl": "زوزه",
+ "growling": "درحال غرغر",
+ "meow": "میو",
+ "caterwaul": "جیغوداد",
+ "livestock": "دام",
+ "clip_clop": "تقتق",
+ "cattle": "گوساله",
+ "cowbell": "زنگولهٔ گاو",
+ "mouse": "موش",
+ "oink": "خِرخِر",
+ "keyboard": "صفحهکلید",
+ "goat": "بز",
+ "sink": "سینک",
+ "cluck": "قُدقُد",
+ "turkey": "بوقلمون",
+ "quack": "قاقا",
+ "scissors": "قیچی",
+ "honk": "بوق",
+ "hair_dryer": "سشوار",
+ "roar": "غرش",
+ "vehicle": "وسیلهٔ نقلیه",
+ "chirp": "جیکجیک",
+ "squawk": "جیغ زدن",
+ "coo": "قوقو",
+ "crow": "کلاغ",
+ "owl": "جغد",
+ "dogs": "سگها",
+ "patter": "شرشر",
+ "mosquito": "پشه",
+ "buzz": "وزوز",
+ "frog": "قورباغه",
+ "snake": "مار",
+ "rattle": "جغجغه کردن",
+ "music": "موسیقی",
+ "musical_instrument": "ساز موسیقی",
+ "guitar": "گیتار",
+ "electric_guitar": "گیتار برقی",
+ "acoustic_guitar": "گیتار آکوستیک",
+ "steel_guitar": "گیتار استیل",
+ "banjo": "بانجو",
+ "sitar": "سیتار",
+ "hiccup": "سکسکه",
+ "fart": "باد معده",
+ "finger_snapping": "بشکن زدن",
+ "clapping": "دست زدن",
+ "heartbeat": "ضربان قلب",
+ "heart_murmur": "سوفل قلبی",
+ "applause": "تشویق",
+ "chatter": "وراجی",
+ "crowd": "جمعیت",
+ "children_playing": "بازی کردن کودکان",
+ "animal": "حیوان",
+ "pets": "حیوانات خانگی",
+ "bark": "پارس",
+ "bow_wow": "هاپهاپ",
+ "whimper_dog": "نالیدن سگ",
+ "purr": "خرخر",
+ "hiss": "هیس",
+ "neigh": "شیهه",
+ "door": "در",
+ "moo": "ماغ",
+ "pig": "خوک",
+ "bleat": "بعبع",
+ "fowl": "ماکیان",
+ "cock_a_doodle_doo": "قدقدیقدقد",
+ "blender": "مخلوطکن",
+ "chicken": "مرغ",
+ "gobble": "قورت دادن",
+ "clock": "ساعت",
+ "duck": "اردک",
+ "goose": "غاز",
+ "wild_animals": "حیوانات وحشی",
+ "toothbrush": "مسواک",
+ "roaring_cats": "غرش گربهها",
+ "pigeon": "کبوتر",
+ "hoot": "هوهو",
+ "flapping_wings": "بالبال زدن",
+ "rats": "موشها",
+ "insect": "حشره",
+ "cricket": "جیرجیرک",
+ "fly": "مگس",
+ "croak": "قارقار",
+ "whale_vocalization": "آواز نهنگ",
+ "plucked_string_instrument": "ساز زهی زخمهای",
+ "bass_guitar": "گیتار باس",
+ "tapping": "ضربهزدن",
+ "strum": "زخمهزدن",
+ "mandolin": "ماندولین",
+ "zither": "زیتر",
+ "ukulele": "یوکللی",
+ "piano": "پیانو",
+ "electric_piano": "پیانوی الکتریکی",
+ "organ": "ارگ",
+ "electronic_organ": "ارگ الکترونیکی",
+ "hammond_organ": "ارگ هموند",
+ "synthesizer": "سینتیسایزر",
+ "sampler": "سمپلر",
+ "harpsichord": "هارپسیکورد",
+ "percussion": "سازهای کوبهای",
+ "drum_kit": "ست درام",
+ "drum_machine": "درام ماشین",
+ "drum": "درام",
+ "snare_drum": "درام اسنیر",
+ "rimshot": "ریمشات",
+ "drum_roll": "درام رول",
+ "bass_drum": "درام باس",
+ "timpani": "تیمپانی",
+ "tabla": "طبلا",
+ "cymbal": "سنج",
+ "hi_hat": "هایهت",
+ "wood_block": "بلوک چوبی",
+ "tambourine": "تامبورین",
+ "maraca": "ماراکا",
+ "gong": "گونگ",
+ "tubular_bells": "ناقوسهای لولهای",
+ "mallet_percussion": "سازهای کوبهای مالت",
+ "marimba": "ماریمبا",
+ "glockenspiel": "گلوکناشپیل",
+ "vibraphone": "ویبرافون",
+ "steelpan": "استیلپن",
+ "orchestra": "ارکستر",
+ "brass_instrument": "ساز بادی برنجی",
+ "french_horn": "هورن فرانسوی",
+ "trumpet": "ترومپت",
+ "trombone": "ترومبون",
+ "bowed_string_instrument": "ساز زهی آرشهای",
+ "string_section": "بخش سازهای زهی",
+ "violin": "ویولن",
+ "pizzicato": "پیتزیکاتو",
+ "cello": "ویولنسل",
+ "double_bass": "کنترباس",
+ "wind_instrument": "ساز بادی",
+ "flute": "فلوت",
+ "saxophone": "ساکسوفون",
+ "clarinet": "کلارینت",
+ "harp": "چنگ",
+ "bell": "ناقوس",
+ "church_bell": "ناقوس کلیسا",
+ "jingle_bell": "زنگوله",
+ "bicycle_bell": "زنگ دوچرخه",
+ "tuning_fork": "دیاپازون",
+ "chime": "زنگ",
+ "wind_chime": "زنگ باد",
+ "harmonica": "سازدهنی",
+ "accordion": "آکاردئون",
+ "bagpipes": "نیانبان",
+ "didgeridoo": "دیجریدو",
+ "theremin": "ترمین",
+ "singing_bowl": "کاسهٔ آوازخوان",
+ "scratching": "خراشیدن",
+ "pop_music": "موسیقی پاپ",
+ "hip_hop_music": "موسیقی هیپهاپ",
+ "beatboxing": "بیتباکس",
+ "rock_music": "موسیقی راک",
+ "heavy_metal": "هوی متال",
+ "punk_rock": "پانک راک",
+ "grunge": "گرانج",
+ "progressive_rock": "راک پراگرسیو",
+ "rock_and_roll": "راک اند رول",
+ "psychedelic_rock": "راک روانگردان",
+ "rhythm_and_blues": "ریتم اند بلوز",
+ "soul_music": "موسیقی سول",
+ "reggae": "رگی",
+ "country": "کانتری",
+ "swing_music": "موسیقی سوئینگ",
+ "bluegrass": "بلوگرس",
+ "funk": "فانک",
+ "folk_music": "موسیقی فولک",
+ "jazz": "جاز",
+ "disco": "دیسکو",
+ "classical_music": "موسیقی کلاسیک",
+ "opera": "اپرا",
+ "electronic_music": "موسیقی الکترونیک",
+ "house_music": "موسیقی هاوس",
+ "techno": "تکنو",
+ "dubstep": "داباستپ",
+ "drum_and_bass": "درام اند بیس",
+ "electronica": "الکترونیکا",
+ "electronic_dance_music": "موسیقی رقص الکترونیک",
+ "ambient_music": "موسیقی امبینت",
+ "trance_music": "موسیقی ترنس",
+ "music_of_latin_america": "موسیقی آمریکای لاتین",
+ "salsa_music": "موسیقی سالسا",
+ "flamenco": "فلامنکو",
+ "blues": "بلوز",
+ "music_for_children": "موسیقی برای کودکان",
+ "new-age_music": "موسیقی نیو ایج",
+ "vocal_music": "موسیقی آوازی",
+ "a_capella": "آکاپلا",
+ "music_of_africa": "موسیقی آفریقا",
+ "afrobeat": "آفروبیت",
+ "christian_music": "موسیقی مسیحی",
+ "gospel_music": "موسیقی گاسپل",
+ "music_of_asia": "موسیقی آسیا",
+ "carnatic_music": "موسیقی کارناتیک",
+ "music_of_bollywood": "موسیقی بالیوود",
+ "ska": "اسکا",
+ "traditional_music": "موسیقی سنتی",
+ "independent_music": "موسیقی مستقل",
+ "song": "آهنگ",
+ "background_music": "موسیقی پسزمینه",
+ "theme_music": "موسیقی تم",
+ "soundtrack_music": "موسیقی متن",
+ "lullaby": "لالایی",
+ "video_game_music": "موسیقی بازیهای ویدیویی",
+ "christmas_music": "موسیقی کریسمس",
+ "dance_music": "موسیقی رقص",
+ "wedding_music": "موسیقی عروسی",
+ "happy_music": "موسیقی شاد",
+ "sad_music": "موسیقی غمگین",
+ "tender_music": "موسیقی لطیف",
+ "angry_music": "موسیقی خشمگین",
+ "exciting_music": "موسیقی هیجانانگیز",
+ "scary_music": "موسیقی ترسناک",
+ "wind": "باد",
+ "rustling_leaves": "خشخش برگها",
+ "wind_noise": "صدای باد",
+ "thunderstorm": "طوفان تندری",
+ "thunder": "رعد",
+ "water": "آب",
+ "rain": "باران",
+ "raindrop": "قطرهٔ باران",
+ "rain_on_surface": "باران روی سطح",
+ "waterfall": "آبشار",
+ "ocean": "اقیانوس",
+ "waves": "امواج",
+ "steam": "بخار",
+ "gurgling": "قلقل",
+ "motorboat": "قایق موتوری",
+ "ship": "کشتی",
+ "motor_vehicle": "وسیلهٔ نقلیهٔ موتوری",
+ "toot": "توت",
+ "car_alarm": "دزدگیر خودرو",
+ "truck": "کامیون",
+ "air_brake": "ترمز بادی",
+ "air_horn": "بوق بادی",
+ "reversing_beeps": "بوق دندهعقب",
+ "ice_cream_truck": "کامیون بستنیفروشی",
+ "traffic_noise": "صدای ترافیک",
+ "rail_transport": "حملونقل ریلی",
+ "train_whistle": "سوت قطار",
+ "train_horn": "بوق قطار",
+ "jet_engine": "موتور جت",
+ "propeller": "ملخ",
+ "helicopter": "بالگرد",
+ "fixed-wing_aircraft": "هواپیمای بالثابت",
+ "medium_engine": "موتور متوسط",
+ "heavy_engine": "موتور سنگین",
+ "engine_knocking": "تقتق موتور",
+ "engine_starting": "روشن شدن موتور",
+ "idling": "درجا کار کردن",
+ "slam": "محکم کوبیدن",
+ "knock": "در زدن",
+ "tap": "ضربهٔ آرام",
+ "squeak": "جیرجیر",
+ "cupboard_open_or_close": "باز یا بسته شدن کمد",
+ "microwave_oven": "مایکروفر",
+ "water_tap": "شیر آب",
+ "bathtub": "وان حمام",
+ "toilet_flush": "سیفون توالت",
+ "keys_jangling": "جرینگجرینگ کلیدها",
+ "coin": "سکه",
+ "electric_shaver": "ریشتراش برقی",
+ "shuffling_cards": "بر زدنِ کارتها",
+ "telephone_bell_ringing": "زنگ خوردن تلفن",
+ "ringtone": "زنگ تماس",
+ "telephone_dialing": "شمارهگیری تلفن",
+ "dial_tone": "بوق آزاد",
+ "busy_signal": "بوق اشغال",
+ "alarm_clock": "ساعت زنگدار",
+ "fire_alarm": "هشدار آتشسوزی",
+ "foghorn": "بوق مه",
+ "whistle": "سوت",
+ "steam_whistle": "سوت بخار",
+ "mechanisms": "سازوکارها",
+ "pulleys": "قرقرهها",
+ "sewing_machine": "چرخ خیاطی",
+ "mechanical_fan": "پنکهٔ مکانیکی",
+ "air_conditioning": "تهویهٔ مطبوع",
+ "cash_register": "صندوق فروش",
+ "jackhammer": "چکش بادی",
+ "sawing": "ارهکردن",
+ "drill": "دریل",
+ "sanding": "سنبادهکاری",
+ "power_tool": "ابزار برقی",
+ "filing": "سوهانکاری",
+ "artillery_fire": "آتش توپخانه",
+ "cap_gun": "تفنگ ترقهای",
+ "fireworks": "آتشبازی",
+ "firecracker": "ترقه",
+ "burst": "ترکیدن",
+ "crack": "ترک",
+ "glass": "شیشه",
+ "chink": "جرینگ",
+ "shatter": "خُرد شدن",
+ "silence": "سکوت",
+ "television": "تلویزیون",
+ "radio": "رادیو",
+ "field_recording": "ضبط میدانی",
+ "scream": "جیغ",
+ "chird": "جیرجیر",
+ "change_ringing": "زنگ خوردن پول خرد",
+ "shofar": "شوفار",
+ "liquid": "مایع",
+ "splash": "پاشیدن",
+ "gush": "فوران",
+ "fill": "پر کردن",
+ "spray": "اسپری",
+ "pump": "پمپ",
+ "stir": "هم زدن",
+ "thunk": "صدای افتادن",
+ "electronic_tuner": "تیونر الکترونیکی",
+ "effects_unit": "واحد افکتها",
+ "chorus_effect": "افکت کُر",
+ "basketball_bounce": "پرش توپ بسکتبال",
+ "bouncing": "پرش",
+ "whip": "شلاق",
+ "flap": "بالبال زدن",
+ "scratch": "خراشیدن",
+ "scrape": "ساییدن",
+ "beep": "بیپ",
+ "ping": "پینگ",
+ "ding": "دینگ",
+ "clang": "تق",
+ "squeal": "جیغ",
+ "clicking": "کلیککردن",
+ "clickety_clack": "تَقتَق",
+ "rumble": "غرّش",
+ "plop": "پَت",
+ "chirp_tone": "صدای جیک",
+ "pulse": "پالس",
+ "inside": "داخل",
+ "outside": "بیرون",
+ "reverberation": "پژواک",
+ "cacophony": "همهمه",
+ "throbbing": "تپش",
+ "vibration": "لرزش",
+ "hands": "دستها",
+ "cheering": "تشویق کردن",
+ "caw": "قارقار",
+ "jingle": "جینگل",
+ "middle_eastern_music": "موسیقی خاورمیانهای",
+ "stream": "جریان",
+ "fire": "آتش",
+ "crackle": "ترقتروق",
+ "sailboat": "قایق بادبانی",
+ "rowboat": "قایق پارویی",
+ "power_windows": "شیشهبالابر برقی",
+ "skidding": "سرخوردن",
+ "tire_squeal": "جیغ لاستیک",
+ "car_passing_by": "عبور خودرو",
+ "race_car": "خودروی مسابقه",
+ "emergency_vehicle": "خودروی امدادی",
+ "police_car": "خودروی پلیس",
+ "vacuum_cleaner": "جاروبرقی",
+ "zipper": "زیپ",
+ "typing": "تایپ کردن",
+ "typewriter": "ماشین تحریر",
+ "computer_keyboard": "صفحهکلید رایانه",
+ "writing": "نوشتن",
+ "alarm": "هشدار",
+ "telephone": "تلفن",
+ "siren": "آژیر",
+ "civil_defense_siren": "آژیر دفاع مدنی",
+ "buzzer": "بیزر",
+ "smoke_detector": "آشکارساز دود",
+ "ratchet": "جغجغه",
+ "tick-tock": "تیکتاک",
+ "gears": "چرخدندهها",
+ "printer": "چاپگر",
+ "single-lens_reflex_camera": "دوربین تکلنزی بازتابی",
+ "tools": "ابزارها",
+ "hammer": "چکش",
+ "explosion": "انفجار",
+ "gunshot": "شلیک",
+ "machine_gun": "مسلسل",
+ "fusillade": "رگبار",
+ "eruption": "فوران",
+ "boom": "بوم",
+ "wood": "چوب",
+ "sound_effect": "جلوهٔ صوتی",
+ "splinter": "تراشه",
+ "environmental_noise": "نویز محیطی",
+ "static": "ساکن",
+ "white_noise": "نویز سفید",
+ "squish": "فشردن",
+ "drip": "چکه",
+ "pour": "ریختن",
+ "trickle": "چکیدن",
+ "boiling": "جوشیدن",
+ "thump": "کوبیدن",
+ "bang": "بنگ",
+ "slap": "سیلی",
+ "whack": "ضربه",
+ "smash": "خرد کردن",
+ "roll": "غلتیدن",
+ "crushing": "خرد کردن",
+ "crumpling": "چروک شدن",
+ "tearing": "پاره کردن",
+ "creak": "جیرجیر",
+ "clatter": "قارقار",
+ "sizzle": "جوشیدن",
+ "hum": "زمزمه",
+ "zing": "زنگ",
+ "boing": "بویینگ",
+ "crunch": "خرد کردن",
+ "noise": "نویز",
+ "mains_hum": "زمزمهٔ برق",
+ "distortion": "اعوجاج",
+ "sidetone": "صدای گوشی",
+ "ambulance": "آمبولانس",
+ "fire_engine": "خودروی آتشنشانی",
+ "railroad_car": "واگن راهآهن",
+ "train_wheels_squealing": "جیرجیر چرخهای قطار",
+ "subway": "مترو",
+ "aircraft": "هوانورد",
+ "aircraft_engine": "موتور هواپیما",
+ "engine": "موتور",
+ "light_engine": "موتور سبک",
+ "dental_drill's_drill": "متهٔ دندانپزشکی",
+ "lawn_mower": "چمنزن",
+ "chainsaw": "ارهٔ زنجیری",
+ "accelerating": "شتابگیری",
+ "doorbell": "زنگ در",
+ "ding-dong": "دینگدونگ",
+ "sliding_door": "در کشویی",
+ "drawer_open_or_close": "باز یا بسته شدن کشو",
+ "dishes": "ظروف",
+ "cutlery": "قاشق و چنگال",
+ "chopping": "خرد کردن",
+ "frying": "سرخ کردن",
+ "electric_toothbrush": "مسواک برقی",
+ "tick": "تیک",
+ "chop": "خرد کردن",
+ "pink_noise": "نویز صورتی",
+ "sodeling": "سودلینگ",
+ "slosh": "پاشیدن",
+ "sonar": "سونار",
+ "arrow": "پیکان",
+ "whoosh": "ووش",
+ "breaking": "شکستن",
+ "rub": "مالیدن",
+ "rustle": "خشخش",
+ "whir": "وزوز",
+ "sine_wave": "موج سینوسی",
+ "harmonic": "هارمونیک",
+ "echo": "پژواک"
}
diff --git a/web/public/locales/fa/common.json b/web/public/locales/fa/common.json
index 0967ef424..3b9e02617 100644
--- a/web/public/locales/fa/common.json
+++ b/web/public/locales/fa/common.json
@@ -1 +1,297 @@
-{}
+{
+ "time": {
+ "untilForTime": "تا {{time}}",
+ "untilForRestart": "تا زمانی که فریگیت دوباره شروع به کار کند.",
+ "untilRestart": "تا زمان ریاستارت",
+ "ago": "{{timeAgo}} قبل",
+ "justNow": "هم اکنون",
+ "today": "امروز",
+ "yesterday": "دیروز",
+ "last7": "۷ روز گذشته",
+ "last14": "۱۴ روز گذشته",
+ "last30": "۳۰ روز گذشته",
+ "thisWeek": "این هفته",
+ "lastWeek": "هفتهٔ گذشته",
+ "thisMonth": "این ماه",
+ "lastMonth": "ماه گذشته",
+ "5minutes": "۵ دقیقه",
+ "10minutes": "۱۰ دقیقه",
+ "day_one": "{{time}} روز",
+ "day_other": "{{time}} روز",
+ "h": "{{time}}س",
+ "hour_one": "{{time}} ساعت",
+ "hour_other": "{{time}} ساعت",
+ "m": "{{time}} دقیقه",
+ "minute_one": "{{time}} دقیقه",
+ "minute_other": "{{time}} دقیقه",
+ "s": "{{time}}ث",
+ "30minutes": "۳۰ دقیقه",
+ "1hour": "۱ ساعت",
+ "12hours": "۱۲ ساعت",
+ "24hours": "۲۴ ساعت",
+ "pm": "ب.ظ.",
+ "am": "ق.ظ.",
+ "yr": "{{time}} سال",
+ "year_one": "{{time}} سال",
+ "year_other": "{{time}} سال",
+ "mo": "{{time}} ماه",
+ "month_one": "{{time}} ماه",
+ "month_other": "{{time}} ماه",
+ "d": "{{time}} روز",
+ "second_one": "{{time}} ثانیه",
+ "second_other": "{{time}} ثانیه",
+ "formattedTimestamp": {
+ "12hour": "MMM d، h:mm:ss aaa",
+ "24hour": "MMM d، HH:mm:ss"
+ },
+ "formattedTimestamp2": {
+ "12hour": "MM/dd h:mm:ssa",
+ "24hour": "d MMM HH:mm:ssd MMM، HH:mm:ss"
+ },
+ "formattedTimestampHourMinute": {
+ "12hour": "h:mm aaa",
+ "24hour": "HH:mm"
+ },
+ "formattedTimestampHourMinuteSecond": {
+ "12hour": "h:mm:ss aaa",
+ "24hour": "HH:mm:ss"
+ },
+ "formattedTimestampMonthDayHourMinute": {
+ "12hour": "d MMM, h:mm aaa",
+ "24hour": "d MMM, HH:mm"
+ },
+ "formattedTimestampMonthDayYear": {
+ "12hour": "d MMM, yyyy",
+ "24hour": "d MMM, yyyy"
+ },
+ "formattedTimestampMonthDayYearHourMinute": {
+ "12hour": "d MMM yyyy, h:mm aaa",
+ "24hour": "yyyy MMM d, HH:mm"
+ },
+ "formattedTimestampMonthDay": "d MMM",
+ "formattedTimestampFilename": {
+ "12hour": "MM-dd-yy-h-mm-ss-a",
+ "24hour": "MM-dd-yy-HH-mm-ss"
+ },
+ "inProgress": "در حال انجام",
+ "invalidStartTime": "زمان شروع نامعتبر است",
+ "invalidEndTime": "زمان پایان نامعتبر است"
+ },
+ "unit": {
+ "length": {
+ "feet": "فوت",
+ "meters": "متر"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "gbps": "GB/s",
+ "mbph": "مگابایت/ساعت",
+ "gbph": "گیگابایت/ساعت",
+ "mbps": "مگابایت/ثانیه",
+ "kbph": "کیلوبایت/ساعت"
+ },
+ "speed": {
+ "mph": "مایل/ساعت",
+ "kph": "کیلومتر/ساعت"
+ }
+ },
+ "label": {
+ "hide": "پنهان کردن {{item}}",
+ "ID": "شناسه",
+ "all": "همه",
+ "back": "برگشت به قبل",
+ "show": "نمایش {{item}}",
+ "none": "هیچکدام"
+ },
+ "list": {
+ "many": "{{items}}، و {{last}}",
+ "two": "{{0}} و {{1}}",
+ "separatorWithSpace": ", · "
+ },
+ "field": {
+ "internalID": "شناسهٔ داخلیای که Frigate در پیکربندی و پایگاهداده استفاده میکند",
+ "optional": "اختیاری"
+ },
+ "button": {
+ "apply": "اعمال",
+ "done": "انجام شد",
+ "enable": "فعال کردن",
+ "disabled": "غیرفعال",
+ "cancel": "لغو",
+ "close": "بستن",
+ "back": "بازگشت",
+ "fullscreen": "تمامصفحه",
+ "exitFullscreen": "خروج از حالت تمامصفحه",
+ "twoWayTalk": "مکالمهٔ دوطرفه",
+ "cameraAudio": "صدای دوربین",
+ "off": "خاموش",
+ "delete": "حذف",
+ "download": "دانلود",
+ "unsuspended": "برداشتن تعلیق",
+ "unselect": "لغو انتخاب",
+ "export": "خروجی گرفتن",
+ "next": "بعدی",
+ "reset": "بازنشانی",
+ "enabled": "فعال",
+ "disable": "غیرفعال کردن",
+ "save": "ذخیره",
+ "saving": "در حال ذخیره…",
+ "copy": "کپی",
+ "history": "تاریخچه",
+ "pictureInPicture": "تصویر در تصویر",
+ "copyCoordinates": "کپی مختصات",
+ "yes": "بله",
+ "no": "خیر",
+ "info": "اطلاعات",
+ "play": "پخش",
+ "deleteNow": "حذف فوری",
+ "continue": "ادامه",
+ "on": "روشن",
+ "edit": "ویرایش",
+ "suspended": "تعلیقشده"
+ },
+ "menu": {
+ "systemMetrics": "شاخصهای سیستم",
+ "configuration": "پیکربندی",
+ "settings": "تنظیمات",
+ "language": {
+ "en": "انگلیسی (English)",
+ "hi": "هندی (Hindi)",
+ "fr": "فرانسوی (French)",
+ "ptBR": "پرتغالیِ برزیل (Brazilian Portuguese)",
+ "ru": "روسی (Russian)",
+ "es": "اسپانیایی (زبان اسپانیایی)",
+ "zhCN": "چینی سادهشده (چینی ساده)",
+ "ar": "عربی (زبان عربی)",
+ "pt": "پرتغالی (زبان پرتغالی)",
+ "de": "آلمانی (زبان آلمانی)",
+ "ja": "ژاپنی (زبان ژاپنی)",
+ "tr": "ترکی (زبان ترکی)",
+ "it": "ایتالیایی (زبان ایتالیایی)",
+ "nl": "هلندی (زبان هلندی)",
+ "sv": "سوئدی (زبان سوئدی)",
+ "cs": "چکی (زبان چکی)",
+ "nb": "بوکمل نروژیایی (بوکمل نروژی)",
+ "ko": "کرهای (زبان کرهای)",
+ "vi": "ویتنامی (زبان ویتنامی)",
+ "fa": "فارسی (زبان فارسی)",
+ "pl": "لهستانی (زبان لهستانی)",
+ "uk": "اوکراینی (زبان اوکراینی)",
+ "he": "عبری (زبان عبری)",
+ "el": "یونانی (زبان یونانی)",
+ "ro": "رومانیایی (زبان رومانیایی)",
+ "hu": "مجاری (زبان مجاری)",
+ "fi": "فنلاندی (زبان فنلاندی)",
+ "da": "دانمارکی (زبان دانمارکی)",
+ "sk": "اسلواکی (زبان اسلواکی)",
+ "yue": "کانتونی (زبان کانتونی)",
+ "th": "تایلندی (زبان تایلندی)",
+ "ca": "کاتالانی (زبان کاتالانی)",
+ "sr": "صربی (زبان صربی)",
+ "sl": "اسلوونیایی (زبان اسلوونیایی)",
+ "lt": "لیتوانیایی (زبان لیتوانیایی)",
+ "bg": "بلغاری (زبان بلغاری)",
+ "gl": "گالیسیایی (زبان گالیسیایی)",
+ "id": "اندونزیایی (زبان اندونزیایی)",
+ "ur": "اردو (زبان اردو)",
+ "withSystem": {
+ "label": "برای زبان از تنظیمات سامانه استفاده کنید"
+ }
+ },
+ "system": "سامانه",
+ "systemLogs": "لاگهای سامانه",
+ "configurationEditor": "ویرایشگر پیکربندی",
+ "languages": "زبانها",
+ "appearance": "ظاهر",
+ "darkMode": {
+ "label": "حالت تاریک",
+ "light": "روشنایی",
+ "dark": "تاریک",
+ "withSystem": {
+ "label": "برای حالت روشن یا تاریک از تنظیمات سامانه استفاده کنید"
+ }
+ },
+ "withSystem": "سامانه",
+ "theme": {
+ "label": "پوسته",
+ "blue": "آبی",
+ "green": "سبز",
+ "nord": "نورد",
+ "red": "قرمز",
+ "highcontrast": "کنتراست بالا",
+ "default": "پیشفرض"
+ },
+ "help": "راهنما",
+ "documentation": {
+ "title": "مستندات",
+ "label": "مستندات Frigate"
+ },
+ "restart": "راهاندازی مجدد Frigate",
+ "live": {
+ "title": "زنده",
+ "allCameras": "همهٔ دوربینها",
+ "cameras": {
+ "title": "دوربینها",
+ "count_one": "{{count}} دوربین",
+ "count_other": "{{count}} دوربین"
+ }
+ },
+ "review": "بازبینی",
+ "explore": "کاوش",
+ "export": "خروجی گرفتن",
+ "uiPlayground": "محیط آزمایشی UI",
+ "faceLibrary": "کتابخانهٔ چهره",
+ "classification": "طبقهبندی",
+ "user": {
+ "title": "کاربر",
+ "account": "حساب کاربری",
+ "current": "کاربر فعلی: {{user}}",
+ "anonymous": "ناشناس",
+ "logout": "خروج",
+ "setPassword": "تنظیم گذرواژه"
+ }
+ },
+ "toast": {
+ "copyUrlToClipboard": "نشانی اینترنتی در کلیپبورد کپی شد.",
+ "save": {
+ "title": "ذخیره",
+ "error": {
+ "title": "ذخیرهٔ تغییرات پیکربندی ناموفق بود: {{errorMessage}}",
+ "noMessage": "ذخیرهٔ تغییرات پیکربندی ناموفق بود"
+ }
+ }
+ },
+ "role": {
+ "title": "نقش",
+ "admin": "مدیر",
+ "viewer": "بیننده",
+ "desc": "مدیران به همهٔ ویژگیها در رابط کاربری Frigate دسترسی کامل دارند. بینندهها فقط میتوانند دوربینها، موارد بازبینی و ویدیوهای تاریخی را در رابط کاربری مشاهده کنند."
+ },
+ "pagination": {
+ "label": "صفحهبندی",
+ "previous": {
+ "title": "قبلی",
+ "label": "رفتن به صفحهٔ قبلی"
+ },
+ "next": {
+ "title": "بعدی",
+ "label": "رفتن به صفحهٔ بعدی"
+ },
+ "more": "صفحههای بیشتر"
+ },
+ "accessDenied": {
+ "documentTitle": "دسترسی ممنوع - Frigate",
+ "title": "دسترسی ممنوع",
+ "desc": "شما اجازهٔ مشاهدهٔ این صفحه را ندارید."
+ },
+ "notFound": {
+ "documentTitle": "یافت نشد - Frigate",
+ "title": "۴۰۴",
+ "desc": "صفحه پیدا نشد"
+ },
+ "selectItem": "انتخاب {{item}}",
+ "readTheDocumentation": "مستندات را بخوانید",
+ "information": {
+ "pixels": "{{area}}px"
+ }
+}
diff --git a/web/public/locales/fa/components/auth.json b/web/public/locales/fa/components/auth.json
index 0967ef424..3c4e021b2 100644
--- a/web/public/locales/fa/components/auth.json
+++ b/web/public/locales/fa/components/auth.json
@@ -1 +1,16 @@
-{}
+{
+ "form": {
+ "user": "نام کاربری",
+ "password": "رمز عبور",
+ "login": "ورود",
+ "firstTimeLogin": "اولین باز است وارد می شود؟ اطلاعات هویتی در ثبت رخداد های فریگیت چاپ خواهد شد.",
+ "errors": {
+ "usernameRequired": "وارد کردن نام کاربری الزامی است",
+ "passwordRequired": "وارد کردن رمز عبور الزامی است",
+ "loginFailed": "ورود ناموفق بود",
+ "unknownError": "خطای ناشناخته. گزارشها را بررسی کنید.",
+ "webUnknownError": "خطای ناشناخته. گزارشهای کنسول را بررسی کنید.",
+ "rateLimit": "از حد مجاز درخواستها فراتر رفت. بعداً دوباره تلاش کنید."
+ }
+ }
+}
diff --git a/web/public/locales/fa/components/camera.json b/web/public/locales/fa/components/camera.json
index 0967ef424..35f7ec517 100644
--- a/web/public/locales/fa/components/camera.json
+++ b/web/public/locales/fa/components/camera.json
@@ -1 +1,86 @@
-{}
+{
+ "group": {
+ "label": "گروههای دوربین",
+ "add": "افزودن گروه دوربین",
+ "edit": "ویرایش گروه دوربین",
+ "delete": {
+ "label": "حذف گروه دوربین ها",
+ "confirm": {
+ "title": "تأیید حذف",
+ "desc": "آیا مطمئن هستید که میخواهید گروه دوربین «{{name}}» را حذف کنید؟"
+ }
+ },
+ "name": {
+ "label": "نام",
+ "placeholder": "یک نام وارد کنید…",
+ "errorMessage": {
+ "mustLeastCharacters": "نام گروه دوربین باید حداقل ۲ کاراکتر باشد.",
+ "exists": "نام گروه دوربین از قبل وجود دارد.",
+ "nameMustNotPeriod": "نام گروه دوربین نباید شامل نقطه باشد.",
+ "invalid": "نام گروه دوربین نامعتبر است."
+ }
+ },
+ "cameras": {
+ "desc": "دوربینهای این گروه را انتخاب کنید.",
+ "label": "دوربینها"
+ },
+ "icon": "آیکون",
+ "success": "گروه دوربین ({{name}}) ذخیره شد.",
+ "camera": {
+ "setting": {
+ "streamMethod": {
+ "method": {
+ "noStreaming": {
+ "label": "بدون پخش",
+ "desc": "تصاویر دوربین فقط هر یک دقیقه یکبار بهروزرسانی میشوند و هیچ پخش زندهای انجام نخواهد شد."
+ },
+ "smartStreaming": {
+ "label": "پخش هوشمند (پیشنهادی)",
+ "desc": "پخش هوشمند زمانی که فعالیت قابل تشخیصی وجود ندارد برای صرفهجویی در پهنای باند و منابع، تصویر دوربین شما را هر یک دقیقه یکبار بهروزرسانی میکند. وقتی فعالیت تشخیص داده شود، تصویر بهطور یکپارچه به پخش زنده تغییر میکند."
+ },
+ "continuousStreaming": {
+ "label": "پخش پیوسته",
+ "desc": {
+ "title": "تصویر دوربین وقتی در داشبورد قابل مشاهده باشد همیشه پخش زنده خواهد بود، حتی اگر هیچ فعالیتی تشخیص داده نشود.",
+ "warning": "پخش پیوسته ممکن است باعث مصرف بالای پهنایباند و مشکلات عملکردی شود. با احتیاط استفاده کنید."
+ }
+ }
+ },
+ "label": "روش پخش",
+ "placeholder": "یک روش پخش را انتخاب کنید"
+ },
+ "label": "تنظیمات پخش دوربین",
+ "title": "تنظیمات پخش {{cameraName}}",
+ "audioIsAvailable": "صدا برای این پخش در دسترس است",
+ "audioIsUnavailable": "صدا برای این پخش در دسترس نیست",
+ "audio": {
+ "tips": {
+ "title": "برای این پخش، صدا باید از دوربین شما خروجی گرفته شود و در go2rtc پیکربندی شده باشد."
+ }
+ },
+ "stream": "جریان",
+ "placeholder": "یک جریان را برگزینید",
+ "compatibilityMode": {
+ "label": "حالت سازگاری",
+ "desc": "این گزینه را فقط زمانی فعال کنید که پخش زندهٔ دوربین شما دچار آثار رنگی (artifact) است و در سمت راست تصویر یک خط مورب دیده میشود."
+ },
+ "desc": "گزینههای پخش زنده را برای داشبورد این گروه دوربین تغییر دهید. این تنظیمات مخصوص دستگاه/مرورگر هستند. "
+ },
+ "birdseye": "نمای پرنده"
+ }
+ },
+ "debug": {
+ "options": {
+ "label": "تنظیمات",
+ "title": "گزینهها",
+ "showOptions": "نمایش گزینهها",
+ "hideOptions": "پنهان کردن گزینهها"
+ },
+ "boundingBox": "کادر محدوده",
+ "timestamp": "مهر زمانی",
+ "zones": "ناحیهها",
+ "mask": "ماسک",
+ "motion": "حرکت",
+ "regions": "مناطق"
+ }
+}
diff --git a/web/public/locales/fa/components/dialog.json b/web/public/locales/fa/components/dialog.json
index 0967ef424..99095fc9d 100644
--- a/web/public/locales/fa/components/dialog.json
+++ b/web/public/locales/fa/components/dialog.json
@@ -1 +1,122 @@
-{}
+{
+ "restart": {
+ "title": "آیا برای راه اندازی مجدد Frigate مطمئن هستید؟",
+ "button": "ریاستارت",
+ "restarting": {
+ "title": "فریگیت در حال ریاستارت شدن",
+ "content": "صفحه تا {{countdown}} ثانیه دیگر مجددا بارگزاری خواهد شد.",
+ "button": "بارگزاری مجدد هم اکنون اجرا شود"
+ }
+ },
+ "explore": {
+ "plus": {
+ "submitToPlus": {
+ "label": "ارسال به Frigate+",
+ "desc": "اشیایی که در مکانهایی هستند که میخواهید از آنها اجتناب کنید، «مثبت کاذب» محسوب نمیشوند. ارسال آنها بهعنوان مثبت کاذب باعث میشود مدل دچار سردرگمی شود."
+ },
+ "review": {
+ "question": {
+ "label": "این برچسب را برای Frigate Plus تأیید کنید",
+ "ask_a": "آیا این شیء {{label}} است؟",
+ "ask_an": "آیا این شیء یک {{label}} است؟",
+ "ask_full": "آیا این شیء یک {{untranslatedLabel}} ({{translatedLabel}}) است؟"
+ },
+ "state": {
+ "submitted": "ارسال شد"
+ }
+ }
+ },
+ "video": {
+ "viewInHistory": "مشاهده در تاریخچه"
+ }
+ },
+ "export": {
+ "time": {
+ "fromTimeline": "انتخاب از خط زمانی",
+ "lastHour_one": "ساعت گذشته",
+ "lastHour_other": "آخرین {{count}} ساعت",
+ "custom": "سفارشی",
+ "start": {
+ "title": "زمان شروع",
+ "label": "زمان شروع را انتخاب کنید"
+ },
+ "end": {
+ "title": "زمان پایان",
+ "label": "زمان پایان را انتخاب کنید"
+ }
+ },
+ "toast": {
+ "error": {
+ "endTimeMustAfterStartTime": "زمان پایان باید بعد از زمان شروع باشد",
+ "noVaildTimeSelected": "بازهٔ زمانی معتبر انتخاب نشده است",
+ "failed": "شروع خروجیگیری ناموفق بود: {{error}}"
+ },
+ "success": "ساخت خروجی با موفقیت آغاز شد. فایل را در صفحه خروجیها مشاهده کنید.",
+ "view": "مشاهده"
+ },
+ "fromTimeline": {
+ "saveExport": "ذخیرهٔ خروجی",
+ "previewExport": "پیشنمایش خروجی"
+ },
+ "name": {
+ "placeholder": "برای خروجی نام بگذارید"
+ },
+ "select": "انتخاب",
+ "export": "خروجی",
+ "selectOrExport": "انتخاب یا خروجی"
+ },
+ "streaming": {
+ "label": "جریان",
+ "restreaming": {
+ "disabled": "بازپخش برای این دوربین فعال نیست.",
+ "desc": {
+ "title": "برای گزینههای بیشتر نمایش زنده و صدا برای این دوربین، go2rtc را تنظیم کنید."
+ }
+ },
+ "showStats": {
+ "label": "نمایش آمار جریان",
+ "desc": "این گزینه را فعال کنید تا آمار جریان بهصورت پوششی روی تصویر دوربین نمایش داده شود."
+ },
+ "debugView": "نمای اشکالزدایی"
+ },
+ "search": {
+ "saveSearch": {
+ "label": "ذخیره جستوجو",
+ "desc": "برای این جستوجوی ذخیرهشده یک نام وارد کنید.",
+ "placeholder": "برای جستجوی خود یک نام وارد کنید",
+ "success": "جستجو ({{searchName}}) ذخیره شد.",
+ "button": {
+ "save": {
+ "label": "ذخیرهٔ این جستجو"
+ }
+ },
+ "overwrite": "{{searchName}} موجود است. ذخیره سازی منجر به بازنویسی مقدار موجود خواهد شد."
+ }
+ },
+ "recording": {
+ "confirmDelete": {
+ "title": "تأیید حذف",
+ "desc": {
+ "selected": "آیا مطمئن هستید که میخواهید همهٔ ویدیوهای ضبطشدهٔ مرتبط با این مورد بازبینی را حذف کنید؟detect دوربین {{cameraName}} دریافت نشده است، گزارشهای خطا را بررسی کنید"
+ },
+ "cameraDisabled": "دوربین غیرفعال است",
+ "stats": {
+ "streamType": {
+ "title": "نوع جریان:",
+ "short": "نوع"
+ },
+ "bandwidth": {
+ "title": "پهنای باند:",
+ "short": "پهنای باند"
+ },
+ "latency": {
+ "title": "تأخیر:",
+ "value": "{{seconds}} ثانیهها",
+ "short": {
+ "title": "تأخیر",
+ "value": "{{seconds}} ثانیه"
+ }
+ },
+ "totalFrames": "مجموع فریمها:",
+ "droppedFrames": {
+ "title": "فریمهای از دسترفته:",
+ "short": {
+ "title": "از دسترفته",
+ "value": "{{droppedFrames}} فریم"
+ }
+ },
+ "decodedFrames": "فریمهای رمزگشاییشده:",
+ "droppedFrameRate": "نرخ فریمهای از دسترفته:"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "فریم با موفقیت به Frigate+ ارسال شد"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "ارسال فریم به Frigate+ ناموفق بود"
+ }
+ }
+}
diff --git a/web/public/locales/fa/objects.json b/web/public/locales/fa/objects.json
index 278086db2..c2ce4e4cf 100644
--- a/web/public/locales/fa/objects.json
+++ b/web/public/locales/fa/objects.json
@@ -16,5 +16,105 @@
"bird": "پرنده",
"cat": "گربه",
"dog": "سگ",
- "horse": "اسب"
+ "horse": "اسب",
+ "shoe": "کفش",
+ "eye_glasses": "عینک",
+ "handbag": "کیف دستی",
+ "tie": "کراوات",
+ "suitcase": "چمدان",
+ "frisbee": "فریزبی",
+ "sheep": "گوسفند",
+ "cow": "گاو",
+ "elephant": "فیل",
+ "bear": "خرس",
+ "zebra": "گورخر",
+ "giraffe": "زرافه",
+ "hat": "کلاه",
+ "umbrella": "چتر",
+ "skis": "اسکی",
+ "snowboard": "اسنوبورد",
+ "sports_ball": "توپ ورزشی",
+ "kite": "بادبادک",
+ "baseball_bat": "برای استفاده از چند فیلتر، آنها را یکی پس از دیگری با یک فاصله از هم اضافه کنید.چوب بیسبال",
+ "baseball_glove": "دستکش بیسبال",
+ "skateboard": "اسکیتبورد",
+ "hot_dog": "هاتداگ",
+ "cake": "کیک",
+ "couch": "مبل",
+ "bed": "تخت",
+ "dining_table": "میز ناهارخوری",
+ "toilet": "توالت",
+ "tv": "تلویزیون",
+ "mouse": "موش",
+ "keyboard": "صفحهکلید",
+ "goat": "بز",
+ "oven": "فر",
+ "sink": "سینک",
+ "refrigerator": "یخچال",
+ "book": "کتاب",
+ "vase": "گلدان",
+ "scissors": "قیچی",
+ "hair_dryer": "سشوار",
+ "hair_brush": "برس مو",
+ "vehicle": "وسیلهٔ نقلیه",
+ "deer": "گوزن",
+ "fox": "روباه",
+ "raccoon": "راکون",
+ "on_demand": "در صورت نیاز",
+ "license_plate": "پلاک خودرو",
+ "package": "بسته",
+ "amazon": "آمازون",
+ "usps": "USPS",
+ "fedex": "FedEx",
+ "dhl": "DHL",
+ "purolator": "پرولاتور",
+ "postnord": "PostNord",
+ "backpack": "کولهپشتی",
+ "tennis_racket": "راکت تنیس",
+ "bottle": "بطری",
+ "plate": "پلاک",
+ "wine_glass": "جام شراب",
+ "cup": "فنجان",
+ "fork": "چنگال",
+ "knife": "چاقو",
+ "spoon": "قاشق",
+ "bowl": "کاسه",
+ "banana": "موز",
+ "apple": "سیب",
+ "animal": "حیوان",
+ "sandwich": "ساندویچ",
+ "orange": "پرتقال",
+ "broccoli": "بروکلی",
+ "bark": "پارس",
+ "carrot": "هویج",
+ "pizza": "پیتزا",
+ "donut": "دونات",
+ "chair": "صندلی",
+ "potted_plant": "گیاه گلدانی",
+ "mirror": "آینه",
+ "window": "پنجره",
+ "desk": "میز",
+ "door": "در",
+ "laptop": "لپتاپ",
+ "remote": "ریموت",
+ "cell_phone": "گوشی موبایل",
+ "microwave": "مایکروویو",
+ "toaster": "توستر",
+ "blender": "مخلوطکن",
+ "clock": "ساعت",
+ "teddy_bear": "خرس عروسکی",
+ "toothbrush": "مسواک",
+ "squirrel": "سنجاب",
+ "rabbit": "خرگوش",
+ "robot_lawnmower": "چمنزن رباتی",
+ "waste_bin": "سطل زباله",
+ "face": "چهره",
+ "bbq_grill": "گریل کباب",
+ "ups": "یوپیاس",
+ "an_post": "آن پُست",
+ "postnl": "پستاِناِل",
+ "nzpost": "اِنزد پُست",
+ "gls": "جیاِلاِس",
+ "dpd": "دیپیدی",
+ "surfboard": "تخته موج سواری"
}
diff --git a/web/public/locales/fa/views/classificationModel.json b/web/public/locales/fa/views/classificationModel.json
new file mode 100644
index 000000000..b61d55e4d
--- /dev/null
+++ b/web/public/locales/fa/views/classificationModel.json
@@ -0,0 +1,187 @@
+{
+ "button": {
+ "deleteClassificationAttempts": "حذف تصاویر طبقه بندی",
+ "renameCategory": "تغییر نام کلاس",
+ "deleteCategory": "حذف کردن کلاس",
+ "deleteImages": "حذف کردن عکس ها",
+ "trainModel": "مدل آموزش",
+ "addClassification": "افزودن دستهبندی",
+ "deleteModels": "حذف مدلها",
+ "editModel": "ویرایش مدل"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "کلاس حذف شده",
+ "deletedImage": "عکس های حذف شده",
+ "categorizedImage": "تصویر طبقه بندی شده",
+ "trainedModel": "مدل آموزش دیده شده.",
+ "trainingModel": "آموزش دادن مدل با موفقیت شروع شد.",
+ "deletedModel_one": "{{count}} مدل با موفقیت حذف شد",
+ "deletedModel_other": "{{count}} مدل با موفقیت حذف شدند",
+ "updatedModel": "پیکربندی مدل با موفقیت بهروزرسانی شد",
+ "renamedCategory": "نام کلاس با موفقیت به {{name}} تغییر یافت"
+ },
+ "error": {
+ "deleteImageFailed": "حذف نشد: {{errorMessage}}",
+ "deleteCategoryFailed": "کلاس حذف نشد: {{errorMessage}}",
+ "deleteModelFailed": "حذف مدل ناموفق بود: {{errorMessage}}",
+ "categorizeFailed": "دستهبندی تصویر ناموفق بود: {{errorMessage}}",
+ "trainingFailed": "آموزش مدل ناموفق بود. برای جزئیات، گزارشهای Frigate را بررسی کنید.",
+ "trainingFailedToStart": "شروع آموزش مدل ناموفق بود: {{errorMessage}}",
+ "updateModelFailed": "بهروزرسانی مدل ناموفق بود: {{errorMessage}}",
+ "renameCategoryFailed": "تغییر نام کلاس ناموفق بود: {{errorMessage}}"
+ }
+ },
+ "documentTitle": "دسته بندی مدل ها - فریگیت",
+ "description": {
+ "invalidName": "نام نامعتبر، نام ها فقط می توانند شامل حروف، اعداد، فاصله، آپستروف، زیرخط و خط فاصله باشند."
+ },
+ "details": {
+ "none": "هیچکدام",
+ "scoreInfo": "امتیاز، نشان دهنده میانگین دقت در تشخیص و دسته بندی این شیء در بین تمام تشخیصهاست.",
+ "unknown": "ناشناخته"
+ },
+ "tooltip": {
+ "trainingInProgress": "مدل در حال آموزش است",
+ "noNewImages": "هیچ تصویر جدیدی برای آموزش وجود ندارد. ابتدا تصاویر بیشتری را در مجموعهداده دستهبندی کنید.",
+ "noChanges": "از آخرین آموزش، هیچ تغییری در مجموعهداده ایجاد نشده است.",
+ "modelNotReady": "مدل برای آموزش آماده نیست"
+ },
+ "deleteCategory": {
+ "title": "(pending)",
+ "desc": "آیا مطمئن هستید که میخواهید کلاس {{name}} را حذف کنید؟ این کار همهٔ تصاویر مرتبط را برای همیشه حذف میکند و نیاز به آموزش مجدد مدل دارد.",
+ "minClassesTitle": "امکان حذف کلاس وجود ندارد",
+ "minClassesDesc": "یک مدل دستهبندی باید دستکم ۲ کلاس داشته باشد. پیش از حذف این مورد، یک کلاس دیگر اضافه کنید."
+ },
+ "train": {
+ "titleShort": "اخیر",
+ "title": "طبقهبندیهای اخیر",
+ "aria": "انتخاب طبقهبندیهای اخیر"
+ },
+ "deleteModel": {
+ "title": "حذف مدل دستهبندی",
+ "single": "آیا مطمئن هستید که میخواهید {{name}} را حذف کنید؟ این کار همهٔ دادههای مرتبط از جمله تصاویر و دادههای آموزش را برای همیشه حذف میکند. این عمل قابل بازگشت نیست.",
+ "desc_one": "آیا مطمئن هستید که میخواهید این {{count}} مدل را حذف کنید؟ این کار همهٔ دادههای مرتبط از جمله تصاویر و دادههای آموزشی را برای همیشه حذف میکند. این عمل قابل بازگشت نیست.",
+ "desc_other": "آیا مطمئن هستید که میخواهید {{count}} مدل را حذف کنید؟ این کار همهٔ دادههای مرتبط از جمله تصاویر و دادههای آموزشی را برای همیشه حذف میکند. این عمل قابل بازگشت نیست."
+ },
+ "categorizeImage": "طبقهبندی تصویر",
+ "menu": {
+ "states": "حالتها",
+ "objects": "اشیاء"
+ },
+ "noModels": {
+ "object": {
+ "description": "یک مدل سفارشی ایجاد کنید تا اشیای شناساییشده را طبقهبندی کند.",
+ "title": "هیچ مدل طبقهبندی شیء وجود ندارد",
+ "buttonText": "ایجاد مدل شیء"
+ },
+ "state": {
+ "title": "هیچ مدل طبقهبندی حالت وجود ندارد",
+ "description": "یک مدل سفارشی ایجاد کنید تا تغییرات وضعیت را در نواحی مشخصِ دوربین پایش و طبقهبندی کند.",
+ "buttonText": "ایجاد مدل وضعیت"
+ }
+ },
+ "wizard": {
+ "title": "ایجاد طبقهبندی جدید",
+ "steps": {
+ "stateArea": "ناحیهٔ حالت",
+ "nameAndDefine": "نامگذاری و تعریف",
+ "chooseExamples": "انتخاب نمونهها"
+ },
+ "step1": {
+ "description": "مدلهای حالت نواحی ثابت دوربین را برای تغییرات پایش میکنند (مثلاً درِ باز/بسته). مدلهای شیء به اشیای شناساییشده طبقهبندی اضافه میکنند (مثلاً حیوانات شناختهشده، مأموران تحویل، و غیره).",
+ "namePlaceholder": "نام مدل را وارد کنید...",
+ "type": "نوع",
+ "typeObject": "شیء",
+ "objectLabelPlaceholder": "نوع شیء را انتخاب کنید...",
+ "classificationTypeDesc": "زیربرچسبها متن اضافی به برچسب شیء اضافه میکنند (مثلاً «Person: UPS»). ویژگیها فرادادهٔ قابل جستوجو هستند که جداگانه در فرادادهٔ شیء ذخیره میشوند.",
+ "classificationAttribute": "ویژگی",
+ "classes": "کلاسها",
+ "classesTip": "دربارهٔ کلاسها بیشتر بدانید",
+ "classesObjectDesc": "دستهبندیهای مختلف را برای طبقهبندی اشیای شناساییشده تعریف کنید. برای نمونه: «delivery_person»، «resident»، «stranger» برای طبقهبندی افراد.",
+ "errors": {
+ "nameLength": "نام مدل باید ۶۴ نویسه یا کمتر باشد",
+ "classesUnique": "نام کلاسها باید یکتا باشند",
+ "stateRequiresTwoClasses": "مدلهای حالت دستکم به ۲ کلاس نیاز دارند",
+ "objectLabelRequired": "لطفاً یک برچسب شیء را انتخاب کنید",
+ "nameRequired": "نام مدل الزامی است",
+ "nameOnlyNumbers": "نام مدل نمیتواند فقط شامل عدد باشد",
+ "noneNotAllowed": "کلاس «none» مجاز نیست",
+ "classRequired": "حداقل ۱ کلاس لازم است",
+ "objectTypeRequired": "لطفاً یک نوع طبقهبندی را انتخاب کنید"
+ },
+ "name": "نام",
+ "typeState": "وضعیت",
+ "objectLabel": "برچسب شیء",
+ "classificationType": "نوع طبقهبندی",
+ "classificationSubLabel": "زیربرچسب",
+ "classificationTypeTip": "دربارهٔ انواع طبقهبندی بیشتر بدانید",
+ "states": "وضعیتها",
+ "classesStateDesc": "حالتهای مختلفی را که ناحیهٔ دوربین شما میتواند در آن باشد تعریف کنید. برای مثال: «باز» و «بسته» برای یک درِ گاراژ.",
+ "classPlaceholder": "نام کلاس را وارد کنید…"
+ },
+ "step2": {
+ "description": "دوربینها را انتخاب کنید و ناحیهای را که باید برای هر دوربین پایش شود تعریف کنید. مدل، وضعیت این ناحیهها را طبقهبندی میکند.",
+ "cameras": "دوربینها",
+ "noCameras": "برای افزودن دوربینها روی + کلیک کنید",
+ "selectCamera": "انتخاب دوربین",
+ "selectCameraPrompt": "برای تعریف ناحیهٔ پایش، یک دوربین را از فهرست انتخاب کنید"
+ },
+ "step3": {
+ "selectImagesDescription": "برای انتخاب، روی تصاویر کلیک کنید. وقتی کارتان با این کلاس تمام شد روی «ادامه» کلیک کنید.",
+ "generating": {
+ "description": "Frigate در حال استخراج تصاویر نماینده از ضبطهای شماست. ممکن است کمی زمان ببرد…",
+ "title": "در حال تولید تصاویر نمونه"
+ },
+ "retryGenerate": "تلاش دوباره برای تولید",
+ "classifying": "در حال طبقهبندی و آموزش…",
+ "trainingStarted": "آموزش با موفقیت شروع شد",
+ "errors": {
+ "noCameras": "هیچ دوربینی پیکربندی نشده است",
+ "noObjectLabel": "هیچ برچسب شیئی انتخاب نشده است",
+ "generationFailed": "تولید ناموفق بود. لطفاً دوباره تلاش کنید.",
+ "classifyFailed": "طبقهبندی تصاویر ناموفق بود: {{error}}",
+ "generateFailed": "تولید نمونهها ناموفق بود: {{error}}"
+ },
+ "missingStatesWarning": {
+ "title": "نمونههای وضعیتِ جاافتاده",
+ "description": "برای بهترین نتیجه، توصیه میشود برای همهٔ حالتها نمونه انتخاب کنید. میتوانید بدون انتخاب همهٔ حالتها ادامه دهید، اما تا زمانی که همهٔ حالتها تصویر نداشته باشند مدل آموزش داده نمیشود. پس از ادامه، از نمای «طبقهبندیهای اخیر» برای طبقهبندی تصاویرِ حالتهای جاافتاده استفاده کنید، سپس مدل را آموزش دهید."
+ },
+ "allImagesRequired_one": "لطفاً همهٔ تصاویر را طبقهبندی کنید. {{count}} تصویر باقی مانده است.",
+ "allImagesRequired_other": "لطفاً همهٔ تصاویر را طبقهبندی کنید. {{count}} تصویر باقی مانده است.",
+ "training": {
+ "title": "در حال آموزش مدل",
+ "description": "مدل شما در پسزمینه در حال آموزش است. این پنجره را ببندید؛ بهمحض تکمیل آموزش، مدل شما شروع به اجرا میکند."
+ },
+ "noImages": "هیچ تصویر نمونهای تولید نشد",
+ "modelCreated": "مدل با موفقیت ایجاد شد. از نمای «طبقهبندیهای اخیر» برای افزودن تصاویرِ وضعیتهایِ جاافتاده استفاده کنید، سپس مدل را آموزش دهید.",
+ "generateSuccess": "تصاویر نمونه با موفقیت تولید شد",
+ "selectImagesPrompt": "همهٔ تصاویر با {{className}} را انتخاب کنید"
+ }
+ },
+ "edit": {
+ "title": "ویرایش مدل طبقهبندی",
+ "descriptionState": "کلاسهای این مدل طبقهبندی حالت را ویرایش کنید. اعمال تغییرات نیاز به بازآموزی مدل دارد.",
+ "descriptionObject": "نوع شیء و نوع طبقهبندی را برای این مدل طبقهبندی شیء ویرایش کنید.",
+ "stateClassesInfo": "توجه: تغییر کلاسهای وضعیت نیازمند بازآموزی مدل با کلاسهای بهروزرسانیشده است."
+ },
+ "deleteDatasetImages": {
+ "title": "حذف تصاویر مجموعهداده",
+ "desc_one": "آیا مطمئن هستید که میخواهید این {{count}} تصویر را از {{dataset}} حذف کنید؟ این عمل قابل بازگشت نیست و نیاز به بازآموزی مدل دارد.",
+ "desc_other": "آیا مطمئن هستید که میخواهید {{count}} تصویر را از {{dataset}} حذف کنید؟ این عمل قابل بازگشت نیست و نیاز به بازآموزی مدل دارد."
+ },
+ "deleteTrainImages": {
+ "title": "حذف تصاویر آموزش",
+ "desc_one": "آیا مطمئن هستید که میخواهید این {{count}} تصویر را حذف کنید؟ این عمل قابل بازگشت نیست.",
+ "desc_other": "آیا مطمئن هستید که میخواهید {{count}} تصویر را حذف کنید؟ این عمل قابل بازگشت نیست."
+ },
+ "renameCategory": {
+ "title": "تغییر نام کلاس",
+ "desc": "یک نام جدید برای {{name}} وارد کنید. برای اعمال تغییر نام، لازم است مدل را بازآموزی کنید."
+ },
+ "categories": "کلاسها",
+ "createCategory": {
+ "new": "ایجاد کلاس جدید"
+ },
+ "categorizeImageAs": "طبقهبندی تصویر بهعنوان:"
+}
diff --git a/web/public/locales/fa/views/configEditor.json b/web/public/locales/fa/views/configEditor.json
index 0967ef424..c43489dbb 100644
--- a/web/public/locales/fa/views/configEditor.json
+++ b/web/public/locales/fa/views/configEditor.json
@@ -1 +1,18 @@
-{}
+{
+ "documentTitle": "ویرایشگر کانفیگ - فریگیت",
+ "configEditor": "ویرایشگر کانفیگ",
+ "safeConfigEditor": "ویرایشگر تنظیمات (حالت امن)",
+ "safeModeDescription": "فریگیت به دلیل خطا در صحت سنجی پیکربندی، در حالت امن می باشد.",
+ "copyConfig": "کپی پیکربندی",
+ "saveAndRestart": "ذخیره و راهاندازی مجدد",
+ "saveOnly": "فقط ذخیره",
+ "confirm": "بدون ذخیره خارج میشوید؟",
+ "toast": {
+ "success": {
+ "copyToClipboard": "پیکربندی در کلیپبورد کپی شد."
+ },
+ "error": {
+ "savingError": "خطا در ذخیرهسازی پیکربندی"
+ }
+ }
+}
diff --git a/web/public/locales/fa/views/events.json b/web/public/locales/fa/views/events.json
index 0967ef424..cf3ca7871 100644
--- a/web/public/locales/fa/views/events.json
+++ b/web/public/locales/fa/views/events.json
@@ -1 +1,65 @@
-{}
+{
+ "alerts": "هشدارها",
+ "detections": "تشخیصها",
+ "motion": {
+ "label": "حرکت",
+ "only": "فقط حرکتی"
+ },
+ "allCameras": "همه دوربینها",
+ "empty": {
+ "alert": "هیچ هشداری برای بازبینی وجود ندارد",
+ "detection": "هیچ تشخیصی برای بازبینی وجود ندارد",
+ "motion": "هیچ دادهای از حرکت پیدا نشد",
+ "recordingsDisabled": {
+ "title": "ضبطها بایستی فعال باشند",
+ "description": "موارد بازبینی برای یک دوربین تنها درصورتی امکان ساخت دارند که ضبطها برای آن دورین فعال باشد."
+ }
+ },
+ "timeline": "خط زمانی",
+ "timeline.aria": "انتخاب خط زمانی",
+ "zoomIn": "بزرگنمایی",
+ "zoomOut": "کوچکنمایی",
+ "events": {
+ "aria": "انتخاب رویدادها",
+ "noFoundForTimePeriod": "برای این بازهٔ زمانی هیچ رویدادی یافت نشد.",
+ "label": "رویدادها"
+ },
+ "recordings": {
+ "documentTitle": "ضبطها - فریگیت"
+ },
+ "calendarFilter": {
+ "last24Hours": "۲۴ ساعت گذشته"
+ },
+ "markAsReviewed": "علامتگذاری بهعنوان بازبینیشده",
+ "markTheseItemsAsReviewed": "این موارد را بهعنوان بازبینیشده علامتگذاری کنید",
+ "newReviewItems": {
+ "label": "مشاهدهٔ موارد جدید برای بازبینی",
+ "button": "موارد جدید برای بازبینی"
+ },
+ "detail": {
+ "label": "جزئیات",
+ "noDataFound": "دادهای برای بازبینیِ جزئیات وجود ندارد",
+ "aria": "تغییر وضعیتِ نمای جزئیات",
+ "trackedObject_one": "{{count}} شیء",
+ "trackedObject_other": "{{count}} اشیاء",
+ "noObjectDetailData": "دادهٔ جزئیات شیء در دسترس نیست.",
+ "settings": "تنظیمات نمای جزئیات",
+ "alwaysExpandActive": {
+ "title": "همیشه فعال را باز کنید",
+ "desc": "در صورت امکان، همیشه جزئیات شیء مربوط به موردِ بازبینیِ فعال را باز کنید."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "نقطهٔ ردیابیشده",
+ "clickToSeek": "برای رفتن به این زمان کلیک کنید"
+ },
+ "documentTitle": "بازبینی - Frigate",
+ "selected_one": "{{count}} انتخاب شد",
+ "selected_other": "{{count}} انتخاب شدند",
+ "select_all": "همه",
+ "camera": "دوربین",
+ "detected": "گزینههاشناسایی شد",
+ "normalActivity": "عادی",
+ "needsReview": "نیاز به بازبینی",
+ "securityConcern": "نگرانی امنیتی"
+}
diff --git a/web/public/locales/fa/views/explore.json b/web/public/locales/fa/views/explore.json
index 0967ef424..d532878c4 100644
--- a/web/public/locales/fa/views/explore.json
+++ b/web/public/locales/fa/views/explore.json
@@ -1 +1,248 @@
-{}
+{
+ "generativeAI": "هوش مصنوعی تولید کننده",
+ "documentTitle": "کاوش - فریگیت",
+ "exploreMore": "نمایش اشیا {{label}} بیشتر",
+ "details": {
+ "timestamp": "زمان دقیق",
+ "item": {
+ "desc": "بررسی جزئیات مورد",
+ "button": {
+ "viewInExplore": "مشاهده در کاوش",
+ "share": "اشتراکگذاری این مورد بازبینی"
+ },
+ "tips": {
+ "hasMissingObjects": "اگر میخواهید Frigate اشیای ردیابیشده را برای برچسبهای زیر ذخیره کند، پیکربندی خود را تنظیم کنید: {{objects}} ",
+ "mismatch_one": "{{count}} شیء غیرقابلدسترس شناسایی شد و در این مورد بازبینی گنجانده شد. این اشیا یا شرایط لازم برای هشدار یا تشخیص را نداشتند یا قبلاً پاکسازی/حذف شدهاند.",
+ "mismatch_other": "{{count}} شیء غیرقابلدسترس شناسایی شدند و در این مورد بازبینی گنجانده شدند. این اشیا یا شرایط لازم برای هشدار یا تشخیص را نداشتند یا قبلاً پاکسازی/حذف شدهاند."
+ },
+ "toast": {
+ "success": {
+ "regenerate": "یک توضیح جدید از {{provider}} درخواست شد. بسته به سرعت ارائهدهندهٔ شما، بازتولیدِ توضیح جدید ممکن است کمی زمان ببرد.",
+ "updatedLPR": "پلاک با موفقیت بهروزرسانی شد.",
+ "audioTranscription": "درخواست تبدیل گفتارِ صوت با موفقیت ثبت شد. بسته به سرعت سرور Frigate شما، تکمیل تبدیل گفتار ممکن است کمی زمان ببرد.",
+ "updatedSublabel": "زیر برچسب با موفقیت بهروزرسانی شد.",
+ "updatedAttributes": "ویژگیها با موفقیت بهروزرسانی شد."
+ },
+ "error": {
+ "updatedSublabelFailed": "بهروزرسانی زیربرچسب ناموفق بود: {{errorMessage}}",
+ "updatedAttributesFailed": "بهروزرسانی ویژگیها ناموفق بود: {{errorMessage}}",
+ "regenerate": "فراخوانی {{provider}} برای توضیح جدید ناموفق بود: {{errorMessage}}",
+ "updatedLPRFailed": "بهروزرسانی پلاک ناموفق بود: {{errorMessage}}",
+ "audioTranscription": "درخواست رونویسی صدا ناموفق بود: {{errorMessage}}"
+ }
+ },
+ "title": "جزئیات مورد بازبینی"
+ },
+ "editSubLabel": {
+ "title": "ویرایش زیربرچسب",
+ "descNoLabel": "برای این شیء ردیابیشده یک زیربرچسب جدید وارد کنید",
+ "desc": "برای این {{label}} یک زیربرچسب جدید وارد کنید"
+ },
+ "editLPR": {
+ "desc": "برای {{label}} یک مقدار جدید برای پلاک وارد کنید",
+ "descNoLabel": "برای این شیء ردیابیشده یک مقدار جدید برای پلاک وارد کنید",
+ "title": "ویرایش پلاک"
+ },
+ "editAttributes": {
+ "desc": "ویژگیهای طبقهبندی را برای {{label}} انتخاب کنید",
+ "title": "ویرایش ویژگیها"
+ },
+ "topScore": {
+ "label": "بالاترین امتیاز",
+ "info": "بالاترین امتیاز، بالاترین امتیاز میانه برای شیء ردیابیشده است؛ بنابراین ممکن است با امتیازی که روی تصویر بندانگشتیِ نتیجهٔ جستوجو نمایش داده میشود متفاوت باشد."
+ },
+ "recognizedLicensePlate": "پلاک شناساییشده",
+ "estimatedSpeed": "سرعت تخمینی",
+ "objects": "اشیا",
+ "zones": "ناحیهها",
+ "button": {
+ "regenerate": {
+ "title": "بازتولید",
+ "label": "بازسازی توضیح شیء ردیابیشده"
+ },
+ "findSimilar": "یافتن مشابه"
+ },
+ "description": {
+ "placeholder": "توضیحِ شیء ردیابیشده",
+ "label": "توضیحات",
+ "aiTips": "Frigate تا زمانی که چرخهٔ عمر شیء ردیابیشده پایان نیابد، از ارائهدهندهٔ هوش مصنوعی مولد شما درخواست توضیح نمیکند."
+ },
+ "expandRegenerationMenu": "باز کردن منوی بازتولید",
+ "regenerateFromSnapshot": "بازتولید از اسنپشات",
+ "tips": {
+ "descriptionSaved": "توضیح با موفقیت ذخیره شد",
+ "saveDescriptionFailed": "بهروزرسانی توضیح ناموفق بود: {{errorMessage}}"
+ },
+ "label": "برچسب",
+ "snapshotScore": {
+ "label": "امتیاز عکس فوری"
+ },
+ "score": {
+ "label": "امتیاز"
+ },
+ "attributes": "ویژگیهای طبقهبندی",
+ "camera": "دوربین",
+ "regenerateFromThumbnails": "بازسازی از تصاویر بندانگشتی",
+ "title": {
+ "label": "عنوان"
+ }
+ },
+ "exploreIsUnavailable": {
+ "title": "کاوش کردن در دسترس نیست",
+ "embeddingsReindexing": {
+ "startingUp": "درحال شروع…",
+ "context": "پس از اینکه جاسازیهای شیء ردیابیشده، نمایهسازی مجدد را به پایان رساندند، میتوان از کاوش استفاده کرد.",
+ "estimatedTime": "زمان تخمینی باقیمانده:",
+ "finishingShortly": "بهزودی تمام میشود",
+ "step": {
+ "thumbnailsEmbedded": "تصاویر بندانگشتی جاسازیشده: ",
+ "descriptionsEmbedded": "توضیحات جاسازیشده: ",
+ "trackedObjectsProcessed": "اشیای ردیابیشدهٔ پردازششده: "
+ }
+ },
+ "downloadingModels": {
+ "context": "Frigate در حال دانلود مدلهای بردارسازی لازم برای پشتیبانی از قابلیت «جستوجوی معنایی» است. بسته به سرعت اتصال شبکه شما، این کار ممکن است چند دقیقه طول بکشد.",
+ "setup": {
+ "visionModel": "مدل بینایی",
+ "visionModelFeatureExtractor": "استخراجکنندهٔ ویژگیهای مدل بینایی",
+ "textModel": "مدل متنی",
+ "textTokenizer": "توکنساز متن"
+ },
+ "tips": {
+ "context": "ممکن است بخواهید پس از دانلود مدلها، تعبیههای اشیای ردیابیشدهٔ خود را دوباره ایندکس کنید."
+ },
+ "error": "خطایی رخ داده است. گزارشهای Frigate را بررسی کنید."
+ }
+ },
+ "trackingDetails": {
+ "adjustAnnotationSettings": "تنظیمات حاشیهنویسی را تنظیم کنید",
+ "scrollViewTips": "برای مشاهدهٔ لحظههای مهم چرخهٔ زندگی این شیء کلیک کنید.",
+ "autoTrackingTips": "موقعیت کادرها برای دوربینهای ردیابی خودکار دقیق نخواهد بود.",
+ "count": "{{first}} از {{second}}",
+ "trackedPoint": "نقطهٔ ردیابیشده",
+ "lifecycleItemDesc": {
+ "visible": "{{label}} شناسایی شد",
+ "entered_zone": "{{label}} وارد {{zones}} شد",
+ "active": "{{label}} فعال شد",
+ "stationary": "{{label}} ساکن شد",
+ "attribute": {
+ "faceOrLicense_plate": "{{attribute}} برای {{label}} شناسایی شد",
+ "other": "{{label}} بهعنوان {{attribute}} شناسایی شد"
+ },
+ "gone": "{{label}} خارج شد",
+ "heard": "{{label}} شنیده شد",
+ "external": "{{label}} شناسایی شد",
+ "header": {
+ "zones": "ناحیهها",
+ "ratio": "نسبت",
+ "area": "مساحت",
+ "score": "امتیاز"
+ }
+ },
+ "title": "جزئیات ردیابی",
+ "noImageFound": "برای این برچسب زمانی هیچ تصویری یافت نشد.",
+ "createObjectMask": "ایجاد ماسک شیء",
+ "annotationSettings": {
+ "title": "تنظیمات حاشیهنویسی",
+ "showAllZones": {
+ "title": "نمایش همهٔ مناطق",
+ "desc": "همیشه مناطق را روی فریمهایی که اشیا وارد یک منطقه شدهاند نمایش دهید."
+ },
+ "offset": {
+ "toast": {
+ "success": "افست حاشیهنویسی برای {{camera}} در فایل پیکربندی ذخیره شد."
+ },
+ "label": "افست حاشیهنویسی",
+ "desc": "این داده از فید تشخیص دوربین شما میآید، اما روی تصاویر فید ضبطشده قرار میگیرد. بعید است این دو جریان کاملاً همزمان باشند. در نتیجه، کادر محدوده و ویدیو دقیقاً روی هم منطبق نخواهند بود. میتوانید با این تنظیمات، حاشیهنویسیها را در زمان به جلو یا عقب جابهجا کنید تا با ویدئوی ضبطشده بهتر همتراز شوند.",
+ "millisecondsToOffset": "میلیثانیه برای جابهجایی حاشیهنویسیهای تشخیص. پیشفرض: 0 ",
+ "tips": "اگر پخش ویدیو جلوتر از کادرها و نقاط مسیر است مقدار را کمتر کنید و اگر پخش ویدیو عقبتر از آنهاست مقدار را بیشتر کنید. این مقدار میتواند منفی باشد."
+ }
+ },
+ "carousel": {
+ "previous": "اسلاید قبلی",
+ "next": "اسلاید بعدی"
+ }
+ },
+ "trackedObjectDetails": "جزئیات شیء ردیابیشده",
+ "type": {
+ "details": "جزئیاتها",
+ "snapshot": "عکس فوری",
+ "thumbnail": "پیشنمایش",
+ "video": "ویدیو",
+ "tracking_details": "جزئیات ردیابی"
+ },
+ "itemMenu": {
+ "downloadVideo": {
+ "aria": "دانلود ویدئو",
+ "label": "دانلود ویدیو"
+ },
+ "downloadSnapshot": {
+ "label": "دانلود اسنپشات",
+ "aria": "دانلود عکس"
+ },
+ "downloadCleanSnapshot": {
+ "label": "دانلود اسنپشاتِ بدون کادر",
+ "aria": "دانلود عکس فوری بدون کادر"
+ },
+ "viewTrackingDetails": {
+ "aria": "نمایش جزئیات ردیابی",
+ "label": "مشاهدهٔ جزئیات ردیابی"
+ },
+ "findSimilar": {
+ "label": "یافتن مشابه",
+ "aria": "یافتن اشیای ردیابیشدهٔ مشابه"
+ },
+ "addTrigger": {
+ "label": "افزودن تریگر",
+ "aria": "افزودن تریگر برای این شیء ردیابیشده"
+ },
+ "audioTranscription": {
+ "aria": "درخواست رونویسیِ صوتی",
+ "label": "رونویسی"
+ },
+ "submitToPlus": {
+ "aria": "ارسال به Frigate Plus",
+ "label": "ارسال به Frigate+"
+ },
+ "viewInHistory": {
+ "label": "مشاهده در تاریخچه",
+ "aria": "مشاهده در تاریخچه"
+ },
+ "showObjectDetails": {
+ "label": "نمایش مسیر شیء"
+ },
+ "hideObjectDetails": {
+ "label": "پنهان کردن مسیر شیء"
+ },
+ "deleteTrackedObject": {
+ "label": "حذف این شیء ردیابیشده"
+ }
+ },
+ "noTrackedObjects": "هیچ شیء ردیابیشدهای پیدا نشد",
+ "fetchingTrackedObjectsFailed": "خطا در دریافت اشیای ردیابیشده: {{errorMessage}}",
+ "trackedObjectsCount_one": "{{count}} شیء ردیابیشده ",
+ "trackedObjectsCount_other": "{{count}} اشیای ردیابیشده ",
+ "dialog": {
+ "confirmDelete": {
+ "title": "تأیید حذف",
+ "desc": "حذف این شیء ردیابیشده عکس فوری، هرگونه امبدینگ ذخیرهشده و هر ورودی مرتبط با جزئیات ردیابی را حذف میکند. فیلم ضبطشدهٔ این شیء ردیابیشده در نمای تاریخ حذف نخواهد شد.جعبههای حرکت
جعبههای قرمز روی نواحی فریمی که در حال حاضر حرکت در آنها تشخیص داده میشود نمایش داده میشوند
" + }, + "paths": { + "desc": "نقاط مهم مسیر شیء ردیابیشده را نشان میدهد", + "tips": "مسیرها
خطها و دایرهها نقاط مهمی را که شیء ردیابیشده در طول چرخهٔ عمر خود طی کرده است نشان میدهند.
", + "title": "مسیرها" + }, + "objectShapeFilterDrawing": { + "title": "رسم فیلتر شکل شیء", + "desc": "برای مشاهدهٔ جزئیات مساحت و نسبت، روی تصویر یک مستطیل رسم کنید", + "tips": "این گزینه را فعال کنید تا بتوانید روی تصویر دوربین یک مستطیل رسم کنید و مساحت و نسبت آن را ببینید. سپس میتوان از این مقادیر برای تنظیم پارامترهای فیلتر شکل شیء در پیکربندی شما استفاده کرد.", + "score": "امتیاز", + "ratio": "نسبت", + "area": "مساحت" + }, + "openCameraWebUI": "رابط وبِ {{camera}} را باز کنید", + "debugging": "انجام اشکالزدایی", + "objectList": "فهرست اشیا", + "noObjects": "هیچ شیئی وجود ندارد", + "timestamp": { + "title": "مهر زمان", + "desc": "نمایش مهر زمان روی تصویر" + }, + "regions": { + "title": "مناطق", + "desc": "نمایش جعبهٔ ناحیهٔ مورد علاقهٔ ارسالشده به تشخیصدهندهٔ شیء", + "tips": "جعبههای ناحیه
جعبههای سبز روشن روی نواحی مورد علاقه در فریم که به تشخیصدهندهٔ شیء ارسال میشوند نمایش داده میشوند.
" + } + }, + "users": { + "management": { + "desc": "حسابهای کاربری این نمونهٔ Frigate را مدیریت کنید.", + "title": "مدیریت کاربران" + }, + "addUser": "افزودن کاربر", + "updatePassword": "بازنشانی گذرواژه", + "toast": { + "success": { + "createUser": "کاربر {{user}} با موفقیت ایجاد شد", + "deleteUser": "کاربر {{user}} با موفقیت حذف شد", + "updatePassword": "گذرواژه با موفقیت بهروزرسانی شد.", + "roleUpdated": "نقش برای {{user}} بهروزرسانی شد" + }, + "error": { + "setPasswordFailed": "ذخیرهٔ گذرواژه ناموفق بود: {{errorMessage}}", + "createUserFailed": "ایجاد کاربر ناموفق بود: {{errorMessage}}", + "deleteUserFailed": "حذف کاربر ناموفق بود: {{errorMessage}}", + "roleUpdateFailed": "بهروزرسانی نقش ناموفق بود: {{errorMessage}}" + } + }, + "table": { + "changeRole": "تغییر نقش کاربر", + "password": "بازنشانی گذرواژه", + "deleteUser": "حذف کاربر", + "username": "نام کاربری", + "actions": "اقدامات", + "role": "نقش", + "noUsers": "هیچ کاربری یافت نشد." + }, + "dialog": { + "form": { + "user": { + "title": "نام کاربری", + "desc": "فقط حروف، اعداد، نقطه و زیرخط مجاز هستند.", + "placeholder": "نام کاربری را وارد کنید" + }, + "password": { + "confirm": { + "title": "تأیید گذرواژه", + "placeholder": "تأیید گذرواژه" + }, + "strength": { + "title": "قدرت گذرواژه: · ", + "weak": "ضعیف", + "medium": "متوسط", + "strong": "قوی", + "veryStrong": "خیلی قوی" + }, + "requirements": { + "digit": "حداقل یک رقم", + "special": "حداقل یک نویسهٔ ویژه (!@#$%^&*(),.?\":{}|<>)", + "title": "الزامات رمز عبور:", + "length": "حداقل ۸ کاراکتر", + "uppercase": "حداقل یک حرف بزرگ" + }, + "match": "گذرواژهها مطابقت دارند", + "notMatch": "گذرواژهها مطابقت ندارند", + "show": "نمایش رمز عبور", + "hide": "پنهان کردن رمز عبور", + "title": "رمز عبور", + "placeholder": "رمز عبور را وارد کنید" + }, + "newPassword": { + "title": "گذرواژهٔ جدید", + "confirm": { + "placeholder": "رمز عبور جدید را دوباره وارد کنید" + }, + "placeholder": "رمز عبور جدید را وارد کنید" + }, + "passwordIsRequired": "گذرواژه الزامی است", + "currentPassword": { + "title": "رمز عبور فعلی", + "placeholder": "رمز عبور فعلی خود را وارد کنید" + }, + "usernameIsRequired": "نام کاربری الزامی است" + }, + "createUser": { + "title": "ایجاد کاربر جدید", + "desc": "یک حساب کاربری جدید اضافه کنید و یک نقش برای دسترسی به بخشهای رابط کاربری Frigate تعیین کنید.", + "usernameOnlyInclude": "نام کاربری فقط میتواند شامل حروف، اعداد، . یا _ باشد", + "confirmPassword": "لطفاً گذرواژهٔ خود را تأیید کنید" + }, + "passwordSetting": { + "currentPasswordRequired": "گذرواژهٔ فعلی الزامی است", + "incorrectCurrentPassword": "گذرواژهٔ فعلی نادرست است", + "passwordVerificationFailed": "اعتبارسنجی گذرواژه ناموفق بود", + "updatePassword": "بهروزرسانی گذرواژه برای {{username}}", + "setPassword": "تنظیم گذرواژه", + "desc": "برای ایمنسازی این حساب، یک گذرواژهٔ قوی بسازید.", + "doNotMatch": "رمزهای عبور مطابقت ندارند", + "multiDeviceWarning": "هر دستگاه دیگری که در آن وارد شدهاید باید ظرف {{refresh_time}} دوباره وارد شود.", + "multiDeviceAdmin": "همچنین میتوانید با چرخش رمز JWT خود، همهٔ کاربران را فوراً مجبور به احراز هویت مجدد کنید.", + "cannotBeEmpty": "رمز عبور نمیتواند خالی باشد" + }, + "changeRole": { + "desc": "بهروزرسانی مجوزها برای {{username}} ", + "roleInfo": { + "intro": "نقش مناسب برای این کاربر را انتخاب کنید:", + "admin": "مدیر", + "adminDesc": "دسترسی کامل به همهٔ قابلیتها.", + "viewer": "بیننده", + "customDesc": "نقش سفارشی با دسترسی مشخص به دوربین.", + "viewerDesc": "محدود به داشبوردهای زنده، بررسی، کاوش و خروجیگیری فقط." + }, + "title": "تغییر نقش کاربر", + "select": "یک نقش انتخاب کنید" + }, + "deleteUser": { + "title": "حذف کاربر", + "desc": "این عمل قابل بازگشت نیست. این کار حساب کاربری را بهطور دائم حذف میکند و همهٔ دادههای مرتبط را حذف میکند.", + "warn": "آیا مطمئن هستید که میخواهید {{username}} را حذف کنید؟" + } + }, + "title": "کاربران" + }, + "roles": { + "table": { + "role": "نقش", + "cameras": "دوربینها", + "actions": "اقدامها", + "noRoles": "هیچ نقش سفارشیای یافت نشد.", + "editCameras": "ویرایش دوربینها", + "deleteRole": "حذف نقش" + }, + "toast": { + "success": { + "createRole": "نقش {{role}} با موفقیت ایجاد شد", + "updateCameras": "دوربینها برای نقش {{role}} بهروزرسانی شدند", + "deleteRole": "نقش {{role}} با موفقیت حذف شد", + "userRolesUpdated_one": "{{count}} کاربری که به این نقش اختصاص داده شده بود به «بیننده» تغییر یافت و اکنون به همهٔ دوربینها دسترسی دارد.", + "userRolesUpdated_other": "{{count}} کاربری که به این نقش اختصاص داده شده بودند به «بیننده» تغییر یافتند و اکنون به همهٔ دوربینها دسترسی دارند." + }, + "error": { + "createRoleFailed": "ایجاد نقش ناموفق بود: {{errorMessage}}", + "updateCamerasFailed": "بهروزرسانی دوربینها ناموفق بود: {{errorMessage}}", + "deleteRoleFailed": "حذف نقش ناموفق بود: {{errorMessage}}", + "userUpdateFailed": "بهروزرسانی نقشهای کاربر ناموفق بود: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "ایجاد نقش جدید", + "desc": "یک نقش جدید اضافه کنید و سطح دسترسی به دوربینها را تعیین کنید." + }, + "form": { + "role": { + "roleExists": "نقشی با این نام از قبل وجود دارد.", + "placeholder": "نام نقش را وارد کنید", + "desc": "فقط حروف، اعداد، نقطه و زیرخط مجاز است.", + "roleIsRequired": "نام نقش الزامی است", + "roleOnlyInclude": "نام نقش فقط میتواند شامل حروف، اعداد، . یا _ باشد", + "title": "نام نقش" + }, + "cameras": { + "title": "دوربینها", + "desc": "دوربینهایی را که این نقش به آنها دسترسی دارد انتخاب کنید. حداقل یک دوربین لازم است.", + "required": "حداقل باید یک دوربین انتخاب شود." + } + }, + "editCameras": { + "title": "ویرایش دوربینهای نقش", + "desc": "بهروزرسانی دسترسی به دوربین برای نقش {{role}} ." + }, + "deleteRole": { + "title": "حذف نقش", + "desc": "این عمل قابل بازگشت نیست. این کار نقش را بهطور دائم حذف میکند و همهٔ کاربرانی که این نقش را دارند به نقش 'بیننده' اختصاص میدهد که دسترسی بیننده به همهٔ دوربینها را میدهد.", + "warn": "آیا مطمئن هستید که میخواهید {{role}} را حذف کنید؟", + "deleting": "در حال حذف…" + } + }, + "management": { + "title": "مدیریت نقش بیننده", + "desc": "مدیریت نقشهای بینندهٔ سفارشی و مجوزهای دسترسی به دوربین آنها برای این نمونهٔ Frigate." + }, + "addRole": "افزودن نقش" + }, + "notification": { + "title": "اعلانها", + "notificationSettings": { + "title": "تنظیمات اعلانها", + "desc": "Frigate میتواند بهصورت بومی وقتی در مرورگر اجرا میشود یا بهعنوان PWA نصب شده است، اعلانهای پوش را به دستگاه شما ارسال کند." + }, + "notificationUnavailable": { + "title": "اعلانها در دسترس نیستند", + "desc": "اعلانهای پوش وب نیاز به یک بستر امن دارند (https://… ). این محدودیت مرورگر است. برای استفاده از اعلانها، بهصورت امن به Frigate دسترسی پیدا کنید."
+ },
+ "globalSettings": {
+ "title": "تنظیمات عمومی",
+ "desc": "بهطور موقت اعلانها را برای دوربینهای مشخص در همهٔ دستگاههای ثبتشده متوقف کنید."
+ },
+ "sendTestNotification": "ارسال اعلان آزمایشی",
+ "unsavedRegistrations": "ثبتنامهای اعلان ذخیرهنشده",
+ "unsavedChanges": "تغییرات اعلان ذخیرهنشده",
+ "active": "اعلانها فعال هستند",
+ "suspended": "اعلانها تعلیق شدهاند {{time}}",
+ "suspendTime": {
+ "suspend": "تعلیق",
+ "5minutes": "تعلیق به مدت ۵ دقیقه",
+ "10minutes": "تعلیق به مدت ۱۰ دقیقه",
+ "30minutes": "تعلیق به مدت ۳۰ دقیقه",
+ "1hour": "تعلیق به مدت ۱ ساعت",
+ "24hours": "متوقف کردن به مدت ۲۴ ساعت",
+ "untilRestart": "متوقف کردن تا راهاندازی مجدد",
+ "12hours": "متوقف کردن به مدت ۱۲ ساعت"
+ },
+ "email": {
+ "title": "ایمیل",
+ "placeholder": "مثلاً example@email.com",
+ "desc": "یک ایمیل معتبر الزامی است و در صورت بروز مشکل در سرویس push برای اطلاعرسانی به شما استفاده میشود."
+ },
+ "cameras": {
+ "title": "دوربینها",
+ "noCameras": "هیچ دوربینی در دسترس نیست",
+ "desc": "انتخاب کنید که برای کدام دوربینها اعلان فعال شود."
+ },
+ "cancelSuspension": "لغو توقف",
+ "toast": {
+ "success": {
+ "registered": "با موفقیت برای اعلانها ثبت شد. راهاندازی مجدد Frigate قبل از ارسال هر اعلانی (از جمله اعلان آزمایشی) الزامی است.",
+ "settingSaved": "تنظیمات اعلان ذخیره شد."
+ },
+ "error": {
+ "registerFailed": "ذخیرهٔ ثبتنام اعلان ناموفق بود."
+ }
+ },
+ "deviceSpecific": "تنظیمات خاص دستگاه",
+ "registerDevice": "ثبت این دستگاه",
+ "unregisterDevice": "لغو ثبت این دستگاه"
+ },
+ "frigatePlus": {
+ "apiKey": {
+ "notValidated": "کلید API Frigate+ شناسایی نشده یا معتبرسازی نشده است",
+ "desc": "کلید API Frigate+ امکان یکپارچهسازی با سرویس Frigate+ را فراهم میکند.",
+ "plusLink": "دربارهٔ Frigate+ بیشتر بخوانید",
+ "title": "کلید API فرigate+",
+ "validated": "کلید API فرigate+ شناسایی و تأیید شد"
+ },
+ "snapshotConfig": {
+ "title": "پیکربندی عکس فوری",
+ "desc": "ارسال به Frigate+ نیازمند فعال بودنِ هم «عکسهای فوری» و هم عکسهای فوریِ clean_copy در پیکربندی شماست.",
+ "cleanCopyWarning": "برای برخی دوربینها عکس فوری فعال است اما clean copy غیرفعال است. برای اینکه بتوانید تصاویر این دوربینها را به Frigate+ ارسال کنید، باید clean_copy را در پیکربندی عکس فوری خود فعال کنید.",
+ "table": {
+ "camera": "دوربین",
+ "snapshots": "عکسهای فوری",
+ "cleanCopySnapshots": "عکسهای فوریِ clean_copy "
+ }
+ },
+ "modelInfo": {
+ "title": "اطلاعات مدل",
+ "loadingAvailableModels": "در حال بارگذاری مدلهای موجود…",
+ "modelSelect": "مدلهای موجود شما در Frigate+ را میتوان از اینجا انتخاب کرد. توجه داشته باشید که فقط مدلهای سازگار با پیکربندی فعلی آشکارساز شما قابل انتخاب هستند.",
+ "modelType": "نوع مدل",
+ "cameras": "دوربینها",
+ "loading": "در حال بارگذاری اطلاعات مدل…",
+ "error": "بارگذاری اطلاعات مدل ناموفق بود",
+ "availableModels": "مدلهای موجود",
+ "trainDate": "تاریخ آموزش",
+ "baseModel": "مدل پایه",
+ "plusModelType": {
+ "baseModel": "مدل پایه",
+ "userModel": "بهینهشده"
+ },
+ "supportedDetectors": "تشخیصدهندههای پشتیبانیشده"
+ },
+ "unsavedChanges": "تغییرات تنظیمات Frigate+ ذخیرهنشده",
+ "restart_required": "نیاز به راهاندازی مجدد (مدل Frigate+ تغییر کرد)",
+ "toast": {
+ "success": "تنظیمات Frigate+ ذخیره شد. برای اعمال تغییرات، Frigate را راهاندازی مجدد کنید.",
+ "error": "ذخیرهٔ تغییرات پیکربندی ناموفق بود: {{errorMessage}}"
+ },
+ "title": "تنظیمات Frigate+"
+ },
+ "triggers": {
+ "documentTitle": "تریگرها",
+ "semanticSearch": {
+ "title": "جستجوی معنایی غیرفعال است",
+ "desc": "برای استفاده از تریگرها باید جستجوی معنایی فعال باشد."
+ },
+ "management": {
+ "title": "تریگرها",
+ "desc": "مدیریت محرکها برای {{camera}}. از نوع بندانگشتی برای فعالسازی روی بندانگشتیهای مشابه به شیء ردیابیشدهٔ انتخابیتان استفاده کنید، و از نوع توضیحات برای فعالسازی روی توضیحات مشابه به متنی که مشخص میکنید."
+ },
+ "table": {
+ "lastTriggered": "آخرین بار فعالشده",
+ "noTriggers": "هیچ محرکی برای این دوربین پیکربندی نشده است.",
+ "edit": "ویرایش",
+ "deleteTrigger": "حذف محرک",
+ "name": "نام",
+ "type": "نوع",
+ "content": "محتوا",
+ "threshold": "آستانه",
+ "actions": "اقدامات"
+ },
+ "type": {
+ "thumbnail": "پیشنمایش",
+ "description": "توضیحات"
+ },
+ "actions": {
+ "notification": "ارسال اعلان",
+ "sub_label": "افزودن زیربرچسب",
+ "attribute": "افزودن ویژگی"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "ایجاد تریگر",
+ "desc": "برای دوربین {{camera}} یک تریگر ایجاد کنید"
+ },
+ "editTrigger": {
+ "title": "ویرایش تریگر",
+ "desc": "تنظیمات تریگر روی دوربین {{camera}} را ویرایش کنید"
+ },
+ "deleteTrigger": {
+ "title": "حذف تریگر",
+ "desc": "آیا مطمئن هستید که میخواهید تریگر {{triggerName}} را حذف کنید؟ این عمل قابل بازگشت نیست."
+ },
+ "form": {
+ "name": {
+ "title": "نام",
+ "placeholder": "این تریگر را نامگذاری کنید",
+ "description": "یک نام یا توضیح یکتا وارد کنید تا این تریگر قابل شناسایی باشد",
+ "error": {
+ "minLength": "فیلد باید حداقل ۲ کاراکتر باشد.",
+ "invalidCharacters": "فیلد فقط میتواند شامل حروف، اعداد، زیرخط (_) و خط تیره (-) باشد.",
+ "alreadyExists": "تریگری با این نام از قبل برای این دوربین وجود دارد."
+ }
+ },
+ "enabled": {
+ "description": "این تریگر را فعال یا غیرفعال کنید"
+ },
+ "type": {
+ "title": "نوع",
+ "placeholder": "نوع تریگر را انتخاب کنید",
+ "description": "وقتی توضیحی مشابهِ شیء ردیابیشده تشخیص داده شود تریگر شود",
+ "thumbnail": "وقتی بندانگشتیِ مشابهِ شیء ردیابیشده تشخیص داده شود تریگر شود"
+ },
+ "content": {
+ "title": "محتوا",
+ "imagePlaceholder": "یک بندانگشتی انتخاب کنید",
+ "textPlaceholder": "محتوای متنی را وارد کنید",
+ "imageDesc": "فقط ۱۰۰ بندانگشتیِ آخر نمایش داده میشوند. اگر بندانگشتیِ موردنظر خود را پیدا نمیکنید، لطفاً اشیای قدیمیتر را در Explore مرور کنید و از همانجا از منو یک تریگر تنظیم کنید.",
+ "textDesc": "متنی وارد کنید تا وقتی توضیحی مشابهِ شیء ردیابیشده تشخیص داده شد، این اقدام تریگر شود.",
+ "error": {
+ "required": "محتوا الزامی است."
+ }
+ },
+ "threshold": {
+ "title": "آستانه",
+ "desc": "آستانهٔ شباهت را برای این تریگر تعیین کنید. آستانهٔ بالاتر یعنی برای فعال شدن تریگر، تطابق نزدیکتری لازم است.",
+ "error": {
+ "min": "آستانه باید حداقل ۰ باشد",
+ "max": "آستانه باید حداکثر ۱ باشد"
+ }
+ },
+ "actions": {
+ "title": "اقدامها",
+ "desc": "بهطور پیشفرض، Frigate برای همهٔ تریگرها یک پیام MQTT ارسال میکند. زیربرچسبها نام تریگر را به برچسب شیء اضافه میکنند. ویژگیها فرادادههای قابل جستجو هستند که جداگانه در فرادادهٔ شیء ردیابیشده ذخیره میشوند.",
+ "error": {
+ "min": "حداقل باید یک اقدام انتخاب شود."
+ }
+ }
+ }
+ },
+ "wizard": {
+ "title": "ایجاد تریگر",
+ "step1": {
+ "description": "تنظیمات پایهٔ تریگر خود را پیکربندی کنید."
+ },
+ "step2": {
+ "description": "محتوایی را که این اقدام را فعال میکند تنظیم کنید."
+ },
+ "step3": {
+ "description": "آستانه و اقدامهای این تریگر را پیکربندی کنید."
+ },
+ "steps": {
+ "nameAndType": "نام و نوع",
+ "configureData": "پیکربندی دادهها",
+ "thresholdAndActions": "آستانه و اقدامها"
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "تریگر {{name}} با موفقیت ایجاد شد.",
+ "updateTrigger": "تریگر {{name}} با موفقیت بهروزرسانی شد.",
+ "deleteTrigger": "تریگر {{name}} با موفقیت حذف شد."
+ },
+ "error": {
+ "createTriggerFailed": "ایجاد تریگر ناموفق بود: {{errorMessage}}",
+ "updateTriggerFailed": "بهروزرسانی تریگر ناموفق بود: {{errorMessage}}",
+ "deleteTriggerFailed": "حذف تریگر ناموفق بود: {{errorMessage}}"
+ }
+ },
+ "addTrigger": "افزودن محرک"
+ }
+}
diff --git a/web/public/locales/fa/views/system.json b/web/public/locales/fa/views/system.json
index 0967ef424..090d4a97f 100644
--- a/web/public/locales/fa/views/system.json
+++ b/web/public/locales/fa/views/system.json
@@ -1 +1,201 @@
-{}
+{
+ "documentTitle": {
+ "cameras": "آمار دوربینها - فریگیت",
+ "storage": "آمار حافظه - فریگیت",
+ "general": "آمار عمومی - فریگیت",
+ "enrichments": "آمار بهینه سازی - فریگیت",
+ "logs": {
+ "frigate": "ثبت رخدادهای فریگیت - فریگیت",
+ "go2rtc": "گزارشهای Go2RTC - فریگیت",
+ "nginx": "گزارشهای Nginx - فریگیت"
+ }
+ },
+ "title": "سیستم",
+ "metrics": "شاخصهای سیستم",
+ "logs": {
+ "download": {
+ "label": "دانلود گزارشها"
+ },
+ "copy": {
+ "label": "کپی در کلیپبورد",
+ "success": "گزارشها در کلیپبورد کپی شدند",
+ "error": "نمیتوان گزارشها را در کلیپبورد کپی کرد"
+ },
+ "type": {
+ "label": "نوع",
+ "timestamp": "برچسب زمانی",
+ "tag": "تگ",
+ "message": "پیام"
+ },
+ "tips": "گزارشها از سرور بهصورت زنده در حال دریافت هستند",
+ "toast": {
+ "error": {
+ "fetchingLogsFailed": "خطا در دریافت گزارشها: {{errorMessage}}",
+ "whileStreamingLogs": "خطا هنگام پخش زندهٔ گزارشها: {{errorMessage}}"
+ }
+ }
+ },
+ "general": {
+ "hardwareInfo": {
+ "title": "اطلاعات سختافزار",
+ "gpuUsage": "مصرف GPU",
+ "gpuMemory": "حافظهٔ GPU",
+ "gpuEncoder": "رمزگذار GPU",
+ "gpuDecoder": "رمزگشای GPU",
+ "gpuInfo": {
+ "vainfoOutput": {
+ "title": "خروجی Vainfo",
+ "returnCode": "کد بازگشتی: {{code}}",
+ "processOutput": "خروجی فرایند:",
+ "processError": "خطای فرایند:"
+ },
+ "nvidiaSMIOutput": {
+ "title": "خروجی Nvidia SMI",
+ "name": "ذخیرهٔ جستوجونام: {{name}}",
+ "driver": "درایور: {{driver}}",
+ "cudaComputerCapability": "قابلیت محاسباتی CUDA: {{cuda_compute}}",
+ "vbios": "اطلاعات VBios: {{vbios}}"
+ },
+ "closeInfo": {
+ "label": "بستن اطلاعات GPU"
+ },
+ "copyInfo": {
+ "label": "کپی اطلاعات GPU"
+ },
+ "toast": {
+ "success": "اطلاعات GPU در کلیپبورد کپی شد"
+ }
+ },
+ "npuUsage": "میزان استفاده از NPU",
+ "npuMemory": "حافظهٔ NPU",
+ "intelGpuWarning": {
+ "title": "هشدار آمار GPU اینتل",
+ "message": "آمار GPU در دسترس نیست",
+ "description": "این یک باگ شناختهشده در ابزارهای گزارشدهی آمار GPU اینتل (intel_gpu_top) است که باعث میشود از کار بیفتد و حتی در مواردی که شتابدهی سختافزاری و تشخیص شیء بهدرستی روی (i)GPU اجرا میشوند، بهطور مکرر میزان استفادهٔ GPU را ۰٪ برگرداند. این مشکل مربوط به Frigate نیست. میتوانید میزبان را ریاستارت کنید تا موقتاً مشکل برطرف شود و تأیید کنید که GPU درست کار میکند. این موضوع روی عملکرد تأثیری ندارد."
+ }
+ },
+ "title": "عمومی",
+ "detector": {
+ "title": "آشکارسازها",
+ "inferenceSpeed": "سرعت استنتاج آشکارساز",
+ "temperature": "دمای آشکارساز",
+ "cpuUsage": "مصرف CPU آشکارساز",
+ "cpuUsageInformation": "CPU برای آمادهسازی دادههای ورودی و خروجی به/از مدلهای تشخیص استفاده میشود. این مقدار مصرف استنتاج را اندازهگیری نمیکند، حتی اگر از GPU یا شتابدهنده استفاده شود.",
+ "memoryUsage": "مصرف حافظهٔ آشکارساز"
+ },
+ "otherProcesses": {
+ "title": "فرایندهای دیگر",
+ "processCpuUsage": "میزان استفادهٔ CPU فرایند",
+ "processMemoryUsage": "میزان استفادهٔ حافظهٔ فرایند"
+ }
+ },
+ "storage": {
+ "recordings": {
+ "earliestRecording": "قدیمیترین ضبط موجود:",
+ "title": "ضبطها",
+ "tips": "این مقدار نشاندهندهٔ کل فضای ذخیرهسازیِ استفادهشده توسط ضبطها در پایگاهدادهٔ Frigate است. Frigate میزان استفاده از فضای ذخیرهسازیِ همهٔ فایلهای روی دیسک شما را ردیابی نمیکند."
+ },
+ "shm": {
+ "warning": "اندازهٔ فعلی SHM برابر {{total}}MB خیلی کوچک است. آن را دستکم به {{min_shm}}MB افزایش دهید.",
+ "title": "اختصاص SHM (حافظهٔ اشتراکی)"
+ },
+ "cameraStorage": {
+ "title": "ذخیرهسازی دوربین",
+ "unusedStorageInformation": "اطلاعات فضای ذخیرهسازیِ استفادهنشده",
+ "percentageOfTotalUsed": "درصد از کل",
+ "unused": {
+ "title": "استفادهنشده",
+ "tips": "اگر فایلهای دیگری غیر از ضبطهای Frigate روی دیسک شما ذخیره شده باشد، این مقدار ممکن است فضای آزادِ در دسترس برای Frigate را دقیق نشان ندهد. Frigate میزان استفاده از فضای ذخیرهسازی خارج از ضبطهای خودش را ردیابی نمیکند."
+ },
+ "camera": "دوربین",
+ "storageUsed": "ذخیرهسازی",
+ "bandwidth": "پهنای باند"
+ },
+ "title": "ذخیرهسازی",
+ "overview": "نمای کلی"
+ },
+ "cameras": {
+ "overview": "نمای کلی",
+ "info": {
+ "cameraProbeInfo": "اطلاعات پروب دوربین {{camera}}",
+ "fetching": "در حال دریافت دادههای دوربین",
+ "video": "ویدئو:",
+ "fps": "FPS:",
+ "audio": "صدا:",
+ "aspectRatio": "نسبت تصویر",
+ "streamDataFromFFPROBE": "دادههای جریان با ffprobe بهدست میآید.",
+ "stream": "جریان {{idx}}",
+ "codec": "کدک:",
+ "resolution": "وضوح:",
+ "unknown": "نامشخص",
+ "error": "خطا: {{error}}",
+ "tips": {
+ "title": "اطلاعات بررسی دوربین"
+ }
+ },
+ "framesAndDetections": "فریمها / تشخیصها",
+ "label": {
+ "detect": "تشخیص",
+ "capture": "گرفتن",
+ "overallDetectionsPerSecond": "مجموع تشخیصها در ثانیه",
+ "cameraCapture": "گرفتن {{camName}}",
+ "cameraDetectionsPerSecond": "تشخیصها در ثانیهٔ {{camName}}",
+ "camera": "دوربین",
+ "skipped": "رد شد",
+ "ffmpeg": "FFmpeg",
+ "overallFramesPerSecond": "نرخ کلی فریم بر ثانیه",
+ "overallSkippedDetectionsPerSecond": "نرخ کلی تشخیصهای ردشده بر ثانیه",
+ "cameraDetect": "تشخیص {{camName}}",
+ "cameraFfmpeg": "{{camName}} FFmpeg",
+ "cameraFramesPerSecond": "{{camName}} فریم بر ثانیه",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} تشخیصهای ردشده در ثانیه"
+ },
+ "toast": {
+ "error": {
+ "unableToProbeCamera": "پروبِ دوربین ناموفق بود: {{errorMessage}}"
+ },
+ "success": {
+ "copyToClipboard": "دادههای بررسی در کلیپبورد کپی شد."
+ }
+ },
+ "title": "دوربینها"
+ },
+ "stats": {
+ "ffmpegHighCpuUsage": "{{camera}} استفادهٔ CPU بالایی برای FFmpeg دارد ({{ffmpegAvg}}%)",
+ "detectHighCpuUsage": "{{camera}} استفادهٔ CPU بالایی برای تشخیص دارد ({{detectAvg}}%)",
+ "reindexingEmbeddings": "بازتولید نمایهٔ embeddingها ({{processed}}% تکمیل شده)",
+ "cameraIsOffline": "{{camera}} آفلاین است",
+ "detectIsVerySlow": "{{detect}} بسیار کند است ({{speed}} ms)",
+ "shmTooLow": "اختصاص /dev/shm ({{total}} MB) باید دستکم تا {{min}} MB افزایش یابد.",
+ "healthy": "سامانه سالم است",
+ "detectIsSlow": "{{detect}} کند است ( {{speed}} میلیثانیه )"
+ },
+ "enrichments": {
+ "infPerSecond": "استنتاجها در ثانیه",
+ "embeddings": {
+ "text_embedding": "امبدینگ متن",
+ "image_embedding_speed": "سرعت امبدینگ تصویر",
+ "plate_recognition_speed": "سرعت تشخیص پلاک",
+ "yolov9_plate_detection": "تشخیص پلاک YOLOv9",
+ "review_description_events_per_second": "توضیح بازبینی",
+ "object_description": "توضیح شیء",
+ "image_embedding": "امبدینگ تصویر",
+ "face_recognition": "شناسایی چهره",
+ "plate_recognition": "شناسایی پلاک",
+ "face_embedding_speed": "سرعت امبدینگ چهره",
+ "face_recognition_speed": "سرعت شناسایی چهره",
+ "text_embedding_speed": "سرعت امبدینگ متن",
+ "yolov9_plate_detection_speed": "سرعت تشخیص پلاک YOLOv9",
+ "review_description": "توضیحات بازبینی",
+ "review_description_speed": "سرعت توضیحات بازبینی",
+ "object_description_speed": "سرعت توضیحات شیء",
+ "object_description_events_per_second": "توضیحات شیء",
+ "classification": "طبقهبندی {{name}}",
+ "classification_speed": "سرعت طبقهبندی {{name}}",
+ "classification_events_per_second": "رویدادهای طبقهبندی {{name}} در ثانیه"
+ },
+ "title": "غنیسازیها",
+ "averageInf": "میانگین زمان استنتاج"
+ },
+ "lastRefreshed": "آخرین بهروزرسانی: · "
+}
diff --git a/web/public/locales/fi/audio.json b/web/public/locales/fi/audio.json
index 1623e89bd..f0665039f 100644
--- a/web/public/locales/fi/audio.json
+++ b/web/public/locales/fi/audio.json
@@ -56,7 +56,110 @@
"cough": "Yskä",
"sneeze": "Niistää",
"throat_clearing": "Kurkun selvittäminen",
- "sniff": "Poimi",
- "run": "Käynnistä",
- "shuffle": "Sekoitus"
+ "sniff": "Nuuhkia",
+ "run": "Juokse",
+ "shuffle": "Sekoitus",
+ "hiccup": "Hikka",
+ "radio": "Radio",
+ "television": "Televisio",
+ "environmental_noise": "Ympäristön melu",
+ "sound_effect": "Äänitehoste",
+ "silence": "Hiljaisuus",
+ "glass": "Lasi",
+ "wood": "Puu",
+ "eruption": "Purkaus",
+ "firecracker": "Sähikäinen",
+ "fireworks": "Ilotulitus",
+ "artillery_fire": "Tykistötuli",
+ "machine_gun": "Konekivääri",
+ "explosion": "Räjähdys",
+ "drill": "Pora",
+ "sanding": "Hionta",
+ "sawing": "Sahaus",
+ "hammer": "Vasara",
+ "tools": "Työkalut",
+ "printer": "Tulostin",
+ "cash_register": "Kassakone",
+ "air_conditioning": "Ilmastointi",
+ "mechanical_fan": "Mekaaninen tuuletin",
+ "sewing_machine": "Ompelukone",
+ "gears": "Hammasrattaat",
+ "ratchet": "Räikkä",
+ "pigeon": "Kyyhkynen",
+ "crow": "Varis",
+ "owl": "Pöllö",
+ "flapping_wings": "Siipien räpyttely",
+ "dogs": "Koirat",
+ "rats": "Rotat",
+ "insect": "Hyönteinen",
+ "cricket": "Sirkka",
+ "mosquito": "Hyttynen",
+ "fly": "Kärpänen",
+ "footsteps": "Askelia",
+ "chewing": "Pureskelu",
+ "biting": "Pureminen",
+ "gargling": "Kurlaus",
+ "stomach_rumble": "Vatsan kurina",
+ "burping": "Röyhtäily",
+ "fart": "Pieru",
+ "hands": "Kädet",
+ "finger_snapping": "Sormien napsauttaminen",
+ "clapping": "Taputtaminen",
+ "heartbeat": "Sydämenlyönti",
+ "cheering": "Hurraus",
+ "applause": "Aplodit",
+ "crowd": "Väkijoukko",
+ "children_playing": "Lapset leikkivät",
+ "pets": "Lemmikit",
+ "whimper_dog": "Koiran vinkuminen",
+ "meow": "Miau",
+ "livestock": "Karja",
+ "cattle": "Nautakarja",
+ "cowbell": "Lehmänkello",
+ "pig": "Sika",
+ "chicken": "Kana",
+ "duck": "Ankka",
+ "frog": "Sammakko",
+ "snake": "Käärme",
+ "music": "Musiikki",
+ "musical_instrument": "Musiikki-instrumentti",
+ "guitar": "Kitara",
+ "electric_guitar": "Sähkökitara",
+ "bass_guitar": "Bassokitara",
+ "acoustic_guitar": "Akustinen kitara",
+ "tapping": "Napauttaminen",
+ "piano": "Piano",
+ "electric_piano": "Sähköpiano",
+ "organ": "Urku",
+ "synthesizer": "Syntetisaattori",
+ "drum_kit": "Rumpusetti",
+ "drum": "Rumpu",
+ "wood_block": "Puupalikka",
+ "steelpan": "Teräspannu",
+ "trumpet": "Trumpetti",
+ "violin": "Viulu",
+ "cello": "Sello",
+ "flute": "Huilu",
+ "saxophone": "Saksofoni",
+ "clarinet": "Klarinetti",
+ "harp": "Harppu",
+ "bell": "Kello",
+ "church_bell": "Kirkonkello",
+ "bicycle_bell": "Polkupyörän kello",
+ "tuning_fork": "Virityshaarukka",
+ "pop_music": "Popmusiikki",
+ "hip_hop_music": "Hiphop-musiikki",
+ "rock_music": "Rock-musiikki",
+ "heavy_metal": "Heavy metal",
+ "punk_rock": "Punkrock",
+ "rock_and_roll": "Rock and Roll",
+ "scream": "Huutaa",
+ "accelerating": "Kiihdyttäminen",
+ "air_brake": "Ilmajarru",
+ "aircraft": "Ilma-alus",
+ "aircraft_engine": "Lentokoneen moottori",
+ "alarm": "Hälytys",
+ "ambient_music": "Tunnelmamusiikki",
+ "ambulance": "Ambulanssi",
+ "angry_music": "Vihainen musiikki"
}
diff --git a/web/public/locales/fi/common.json b/web/public/locales/fi/common.json
index f76eb0e67..5cebc8939 100644
--- a/web/public/locales/fi/common.json
+++ b/web/public/locales/fi/common.json
@@ -39,7 +39,10 @@
"minute_one": "{{time}}minuutti",
"minute_other": "{{time}}minuuttia",
"second_one": "{{time}}sekuntti",
- "second_other": "{{time}}sekunttia"
+ "second_other": "{{time}}sekunttia",
+ "formattedTimestampHourMinute": {
+ "24hour": "HH:mm"
+ }
},
"pagination": {
"next": {
@@ -168,5 +171,6 @@
"length": {
"feet": "jalka"
}
- }
+ },
+ "readTheDocumentation": "Lue dokumentaatio"
}
diff --git a/web/public/locales/fi/components/auth.json b/web/public/locales/fi/components/auth.json
index 5ce3ffa02..f81993d86 100644
--- a/web/public/locales/fi/components/auth.json
+++ b/web/public/locales/fi/components/auth.json
@@ -1,7 +1,7 @@
{
"form": {
"password": "Salasana",
- "user": "Käyttäjä",
+ "user": "Käyttäjänimi",
"login": "Kirjaudu",
"errors": {
"usernameRequired": "Käyttäjänimi vaaditaan",
diff --git a/web/public/locales/fi/components/camera.json b/web/public/locales/fi/components/camera.json
index 9dae4c5ed..a641ca65e 100644
--- a/web/public/locales/fi/components/camera.json
+++ b/web/public/locales/fi/components/camera.json
@@ -66,7 +66,8 @@
},
"stream": "Kuvavirta",
"placeholder": "Valitse kuvavirta"
- }
+ },
+ "birdseye": "Linnun silmä"
}
},
"debug": {
diff --git a/web/public/locales/fi/components/dialog.json b/web/public/locales/fi/components/dialog.json
index 9a1ca575d..819e4a55e 100644
--- a/web/public/locales/fi/components/dialog.json
+++ b/web/public/locales/fi/components/dialog.json
@@ -73,5 +73,15 @@
"readTheDocumentation": "Lue dokumentaatio"
}
}
+ },
+ "search": {
+ "saveSearch": {
+ "label": "Tallenna haku"
+ }
+ },
+ "imagePicker": {
+ "search": {
+ "placeholder": "Hae nimikkeen tai alinimikkeen mukaan..."
+ }
}
}
diff --git a/web/public/locales/fi/components/filter.json b/web/public/locales/fi/components/filter.json
index 5a21e5424..c3058bd29 100644
--- a/web/public/locales/fi/components/filter.json
+++ b/web/public/locales/fi/components/filter.json
@@ -56,7 +56,36 @@
"cameras": {
"label": "Kameran suodattimet",
"all": {
- "title": "Kaikki kamerat"
+ "title": "Kaikki kamerat",
+ "short": "Kamerat"
+ }
+ },
+ "classes": {
+ "label": "Luokat",
+ "all": {
+ "title": "Kaikki luokat"
+ },
+ "count_one": "{{count}} Luokka",
+ "count_other": "{{count}} Luokkaa"
+ },
+ "recognizedLicensePlates": {
+ "clearAll": "Tyhjennä kaikki",
+ "title": "Tunnistetut rekisterikilvet",
+ "loadFailed": "Tunnistettujen rekisterikilpien lataaminen epäonnistui.",
+ "loading": "Ladataan tunnistettuja rekisterikilpiä…",
+ "placeholder": "Kirjoita hakeaksesi rekisterikilpeä…",
+ "noLicensePlatesFound": "Rekisterikilpiä ei löytynyt.",
+ "selectPlatesFromList": "Valitse yksi tai useampi rekisterikilpi luettelosta.",
+ "selectAll": "Valitse kaikki"
+ },
+ "logSettings": {
+ "allLogs": "Kaikki lokit",
+ "filterBySeverity": "Suodata lokit vakavuuden mukaan"
+ },
+ "trackedObjectDelete": {
+ "title": "Vahvista poisto",
+ "toast": {
+ "error": "Seurattujen kohteiden poistaminen epäonnistui: {{errorMessage}}"
}
}
}
diff --git a/web/public/locales/fi/views/classificationModel.json b/web/public/locales/fi/views/classificationModel.json
new file mode 100644
index 000000000..477b0e2e9
--- /dev/null
+++ b/web/public/locales/fi/views/classificationModel.json
@@ -0,0 +1,11 @@
+{
+ "documentTitle": "Luokittelumallit - Frigate",
+ "details": {
+ "scoreInfo": "Pistemäärä edustaa tämän objektin kaikkien havaintojen keskimääräistä luokitteluvarmuutta.",
+ "none": "Ei mitään"
+ },
+ "button": {
+ "deleteImages": "Poista kuvat",
+ "trainModel": "Kouluta malli"
+ }
+}
diff --git a/web/public/locales/fi/views/configEditor.json b/web/public/locales/fi/views/configEditor.json
index 472c59e37..96990e140 100644
--- a/web/public/locales/fi/views/configEditor.json
+++ b/web/public/locales/fi/views/configEditor.json
@@ -12,5 +12,7 @@
},
"configEditor": "Konfiguraatioeditori",
"copyConfig": "Kopioi konfiguraatio",
- "saveAndRestart": "Tallenna & uudelleenkäynnistä"
+ "saveAndRestart": "Tallenna & uudelleenkäynnistä",
+ "safeConfigEditor": "Konfiguraatioeditori (vikasietotila)",
+ "safeModeDescription": "Frigate on vikasietotilassa konfiguraation vahvistusvirheen vuoksi."
}
diff --git a/web/public/locales/fi/views/events.json b/web/public/locales/fi/views/events.json
index 638a05f7a..57eb44a80 100644
--- a/web/public/locales/fi/views/events.json
+++ b/web/public/locales/fi/views/events.json
@@ -34,5 +34,7 @@
"label": "Näytä uudet katselmoitavat kohteet",
"button": "Uudet katselmoitavat kohteet"
},
- "camera": "Kamera"
+ "camera": "Kamera",
+ "suspiciousActivity": "Epäilyttävä toiminta",
+ "threateningActivity": "Uhkaava toiminta"
}
diff --git a/web/public/locales/fi/views/explore.json b/web/public/locales/fi/views/explore.json
index c6950c941..25743e470 100644
--- a/web/public/locales/fi/views/explore.json
+++ b/web/public/locales/fi/views/explore.json
@@ -7,7 +7,45 @@
"desc": "Tarkastele kohteen tietoja",
"button": {
"share": "Jaa tämä tarkasteltu kohde"
+ },
+ "toast": {
+ "error": {
+ "updatedSublabelFailed": "Alatunnisteen päivitys epäonnistui",
+ "updatedLPRFailed": "Rekisterikilven päivitys epäonnistui"
+ }
}
+ },
+ "recognizedLicensePlate": "Tunnistettu rekisterikilpi",
+ "estimatedSpeed": "Arvioitu nopeus",
+ "objects": "Objektit",
+ "camera": "Kamera",
+ "zones": "Alueet",
+ "label": "Tunniste",
+ "editSubLabel": {
+ "title": "Editoi alitunnistetta",
+ "desc": "Syötä uusi alitunniste tähän",
+ "descNoLabel": "Lisää uusi alatunniste tähän seurattuun kohteeseen"
+ },
+ "editLPR": {
+ "title": "Muokkaa rekisterikilpeä",
+ "desc": "Syötä uusi rekisterikilven arvo tähän",
+ "descNoLabel": "Syötä uusi rekisterikilven arvo tähän seurattuun objektiin"
+ },
+ "snapshotScore": {
+ "label": "Tilannekuvan arvosana"
+ },
+ "topScore": {
+ "label": "Huippuarvosana",
+ "info": "Ylin pistemäärä on seurattavan kohteen korkein mediaani, joten tämä voi erota hakutuloksen esikatselukuvassa näkyvästä pistemäärästä."
+ },
+ "button": {
+ "findSimilar": "Etsi samankaltaisia"
+ },
+ "description": {
+ "label": "Kuvaus"
+ },
+ "score": {
+ "label": "Pisteet"
}
},
"exploreIsUnavailable": {
@@ -28,7 +66,8 @@
"setup": {
"visionModel": "Vision-malli",
"textModel": "Tekstimalli",
- "textTokenizer": "Tekstin osioija"
+ "textTokenizer": "Tekstin osioija",
+ "visionModelFeatureExtractor": "Näkömallin piirreluokkain"
},
"tips": {
"documentation": "Lue dokumentaatio",
@@ -90,6 +129,27 @@
"downloadSnapshot": {
"label": "Lataa kuvankaappaus",
"aria": "Lataa kuvankaappaus"
+ },
+ "addTrigger": {
+ "label": "Lisää laukaisin",
+ "aria": "Lisää laukaisin tälle seurattavalle kohteelle"
+ },
+ "submitToPlus": {
+ "label": "Lähetä Frigate+:lle"
+ },
+ "downloadVideo": {
+ "label": "Lataa video",
+ "aria": "Lataa video"
+ },
+ "viewObjectLifecycle": {
+ "label": "Tarkastele objektin elinkaarta",
+ "aria": "Näytä objektin elinkaari"
+ },
+ "findSimilar": {
+ "label": "Etsi samankaltaisia"
}
+ },
+ "aiAnalysis": {
+ "title": "AI-analyysi"
}
}
diff --git a/web/public/locales/fi/views/exports.json b/web/public/locales/fi/views/exports.json
index 5ee8e88eb..22f39ceb1 100644
--- a/web/public/locales/fi/views/exports.json
+++ b/web/public/locales/fi/views/exports.json
@@ -13,5 +13,8 @@
"title": "Nimeä uudelleen",
"desc": "Anna uusi nimi viedylle kohteelle.",
"saveExport": "Tallenna vienti"
+ },
+ "tooltip": {
+ "editName": "Muokkaa nimeä"
}
}
diff --git a/web/public/locales/fi/views/faceLibrary.json b/web/public/locales/fi/views/faceLibrary.json
index 041c7324f..dc69f3694 100644
--- a/web/public/locales/fi/views/faceLibrary.json
+++ b/web/public/locales/fi/views/faceLibrary.json
@@ -26,7 +26,8 @@
"toast": {
"success": {
"deletedFace_one": "{{count}} kasvo poistettu onnistuneesti.",
- "deletedFace_other": "{{count}} kasvoa poistettu onnistuneesti."
+ "deletedFace_other": "{{count}} kasvoa poistettu onnistuneesti.",
+ "uploadedImage": "Kuva ladattu onnistuneesti."
}
},
"selectItem": "Valitse {{item}}",
@@ -60,6 +61,22 @@
"desc": "Anna uusi nimi tälle {{name}}"
},
"button": {
- "deleteFaceAttempts": "Poista kasvot"
- }
+ "deleteFaceAttempts": "Poista kasvot",
+ "addFace": "Lisää kasvot",
+ "renameFace": "Uudelleennimeä kasvot",
+ "deleteFace": "Poista kasvot",
+ "uploadImage": "Lataa kuva",
+ "reprocessFace": "Uudelleenprosessointi Kasvot"
+ },
+ "imageEntry": {
+ "validation": {
+ "selectImage": "Valitse kuvatiedosto."
+ },
+ "dropActive": "Pudota kuva tähän…",
+ "dropInstructions": "Vedä ja pudota kuva tähän tai valitse se napsauttamalla",
+ "maxSize": "Maksimikoko: {{size}}MB"
+ },
+ "nofaces": "Kasvoja ei ole saatavilla",
+ "pixels": "{{area}}px",
+ "trainFace": "Kouluta kasvot"
}
diff --git a/web/public/locales/fi/views/live.json b/web/public/locales/fi/views/live.json
index 69c0d23bf..d38703565 100644
--- a/web/public/locales/fi/views/live.json
+++ b/web/public/locales/fi/views/live.json
@@ -43,7 +43,15 @@
"label": "Napsauta kehystä keskittääksesi PTZ-kamera"
}
},
- "presets": "PTZ-kameroiden esiasetukset"
+ "presets": "PTZ-kameroiden esiasetukset",
+ "focus": {
+ "in": {
+ "label": "Tarkenna PTZ-kamera sisään"
+ },
+ "out": {
+ "label": "Tarkenna PTZ-kamera ulos"
+ }
+ }
},
"camera": {
"enable": "Ota kamera käyttöön",
@@ -135,7 +143,8 @@
"recording": "Nauhoitus",
"snapshots": "Tilannekuvat",
"audioDetection": "Äänen tunnistus",
- "autotracking": "Automaattinen seuranta"
+ "autotracking": "Automaattinen seuranta",
+ "transcription": "Äänitranskriptio"
},
"history": {
"label": "Näytä historiallista materiaalia"
@@ -154,5 +163,9 @@
"label": "Muokkaa kameraryhmää"
},
"exitEdit": "Poistu muokkauksesta"
+ },
+ "transcription": {
+ "enable": "Ota käyttöön reaaliaikainen äänitranskriptio",
+ "disable": "Poista käytöstä reaaliaikainen äänitranskriptio"
}
}
diff --git a/web/public/locales/fi/views/search.json b/web/public/locales/fi/views/search.json
index fab605088..887c9e09e 100644
--- a/web/public/locales/fi/views/search.json
+++ b/web/public/locales/fi/views/search.json
@@ -44,7 +44,14 @@
},
"tips": {
"desc": {
- "exampleLabel": "Esimerkki:"
+ "exampleLabel": "Esimerkki:",
+ "step6": "Poista suodattimet napsauttamalla niiden vieressä olevaa 'x' merkkiä.",
+ "text": "Suodattimien avulla voit rajata hakutuloksia. Näin käytät niitä syöttökentässä:",
+ "step1": "Kirjoita suodattimen avaimen nimi ja sen perään kaksoispiste (esim. ”kamerat:”).",
+ "step2": "Valitse arvo ehdotuksista tai kirjoita oma arvo.",
+ "step3": "Käytä useita suodattimia lisäämällä ne peräkkäin välilyönnillä erotettuina.",
+ "step4": "Päivämääräsuodattimet (ennen: ja jälkeen:) käyttävät {{DateFormat}} muotoa.",
+ "step5": "Aikavälin suodatin käyttää {{exampleTime}} muotoa."
},
"title": "Tekstisuodattimien käyttö"
},
@@ -58,5 +65,8 @@
"title": "Samankaltaisten kohteiden haku",
"active": "Samankaltaisuushaku aktiivinen",
"clear": "Poista samankaltaisuushaku"
+ },
+ "placeholder": {
+ "search": "Hae…"
}
}
diff --git a/web/public/locales/fi/views/settings.json b/web/public/locales/fi/views/settings.json
index 23b910dda..df2f2eb56 100644
--- a/web/public/locales/fi/views/settings.json
+++ b/web/public/locales/fi/views/settings.json
@@ -10,7 +10,8 @@
"object": "Virheenjäljitys - Frigate",
"authentication": "Autentikointiuasetukset - Frigate",
"notifications": "Ilmoitusasetukset - Frigate",
- "enrichments": "Laajennusasetukset – Frigate"
+ "enrichments": "Laajennusasetukset – Frigate",
+ "cameraManagement": "Hallitse Kameroita - Frigate"
},
"menu": {
"ui": "Käyttöliittymä",
@@ -22,7 +23,8 @@
"debug": "Debuggaus",
"motionTuner": "Liikesäädin",
"notifications": "Ilmoitukset",
- "enrichments": "Rikasteet"
+ "enrichments": "Rikasteet",
+ "triggers": "Laukaisimet"
},
"dialog": {
"unsavedChanges": {
@@ -176,7 +178,14 @@
"toast": {
"success": "Luokittelumäärityksen tarkistus on tallennettu. Käynnistä Frigate uudelleen muutosten käyttöönottamiseksi."
}
- }
+ },
+ "cameraConfig": {
+ "add": "Lisää kamera",
+ "ffmpeg": {
+ "addInput": "Lisää tulovirta"
+ }
+ },
+ "addCamera": "Lisää uusi kamera"
},
"masksAndZones": {
"filter": {
@@ -415,6 +424,11 @@
"placeholder": "Syötä käyttäjätunnus",
"title": "Käyttäjätunnus"
}
+ },
+ "changeRole": {
+ "roleInfo": {
+ "admin": "Ylläpitäjä"
+ }
}
}
},
@@ -427,5 +441,140 @@
"Threshold": {
"title": "Kynnys"
}
+ },
+ "triggers": {
+ "documentTitle": "Laukaisimet",
+ "management": {
+ "title": "Laukaisimen hallinta"
+ },
+ "addTrigger": "Lisää laukaisin",
+ "table": {
+ "name": "Nimi",
+ "type": "Tyyppi",
+ "content": "Sisältö",
+ "threshold": "Kynnys",
+ "actions": "Toiminnot",
+ "noTriggers": "Tälle kameralle ei ole määritetty laukaisimia.",
+ "edit": "Muokkaa",
+ "deleteTrigger": "Poista laukaisin",
+ "lastTriggered": "Viimeksi laukaistu"
+ },
+ "type": {
+ "thumbnail": "Kuvake",
+ "description": "Kuvaus"
+ },
+ "actions": {
+ "notification": "Lähetä ilmoitus",
+ "alert": "Merkitse hälytykseksi"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "Luo laukaisin",
+ "desc": "Luo laukaisin kameralle {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Muokkaa laukaisinta",
+ "desc": "Muokkaa laukaisimen asetuksia kamerasta {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Poista laukaisin",
+ "desc": "Haluatko varmasti poistaa laukaisimen {{triggerName}}? Tätä toimintoa ei voi peruuttaa."
+ },
+ "form": {
+ "name": {
+ "title": "Nimi",
+ "placeholder": "Syötä laukaisimen nimi",
+ "error": {
+ "minLength": "Nimen on oltava vähintään 2 merkkiä pitkä.",
+ "invalidCharacters": "Nimi voi sisältää vain kirjaimia, numeroita, alaviivoja ja väliviivoja.",
+ "alreadyExists": "Tällä nimellä oleva laukaisin on jo olemassa tälle kameralle."
+ }
+ },
+ "enabled": {
+ "description": "Ota tämä laukaisin käyttöön tai pois käytöstä"
+ },
+ "type": {
+ "title": "Tyyppi",
+ "placeholder": "Valitse laukaisintyyppi"
+ },
+ "content": {
+ "title": "Sisältö",
+ "imagePlaceholder": "Valitse kuva",
+ "textPlaceholder": "Kirjoita tekstisisältö",
+ "imageDesc": "Valitse kuva, joka laukaisee tämän toiminnon, kun samankaltainen kuva havaitaan.",
+ "textDesc": "Syötä teksti, joka laukaisee tämän toiminnon, kun vastaava seurattavan kohteen kuvaus havaitaan.",
+ "error": {
+ "required": "Sisältö on pakollinen."
+ }
+ },
+ "threshold": {
+ "title": "Kynnys",
+ "error": {
+ "min": "Kynnys on oltava vähintään 0",
+ "max": "Kynnys on oltava enintään 1"
+ }
+ },
+ "actions": {
+ "title": "Toiminnot",
+ "desc": "Oletuksena Frigate lähettää MQTT-viestin kaikille laukaisimille. Valitse lisätoiminto, joka suoritetaan, kun tämä laukaisija laukeaa.",
+ "error": {
+ "min": "Vähintään yksi toiminto on valittava."
+ }
+ }
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Laukaisin {{name}} luotu onnistuneesti.",
+ "updateTrigger": "Laukaisin {{name}} päivitetty onnistuneesti.",
+ "deleteTrigger": "Laukaisin {{name}} poistettu onnistuneesti."
+ },
+ "error": {
+ "createTriggerFailed": "Laukaisimen luominen epäonnistui: {{errorMessage}}",
+ "updateTriggerFailed": "Laukaisimen päivitys epäonnistui: {{errorMessage}}",
+ "deleteTriggerFailed": "Laukaisimen poistaminen epäonnistui: {{errorMessage}}"
+ }
+ }
+ },
+ "enrichments": {
+ "semanticSearch": {
+ "modelSize": {
+ "small": {
+ "title": "pieni",
+ "desc": "pieni käyttää kvantisoitua versiota mallista, joka käyttää vähemmän RAM-muistia ja toimii nopeammin CPU:lla, mutta ero upotuksen laadussa on hyvin vähäinen."
+ },
+ "large": {
+ "title": "suuri",
+ "desc": "suuri käyttää koko Jina-mallia ja toimii automaattisesti GPU:lla, jos se on mahdollista."
+ },
+ "desc": "Semanttisen haun upotuksiin käytetyn mallin koko."
+ },
+ "title": "Semanttinen haku",
+ "desc": "Semanttisen haun avulla Frigatessa voit etsiä seurattavia kohteita tarkistettavista kohteista joko kuvan, käyttäjän määrittämän tekstikuvauksen tai automaattisesti luodun kuvauksen avulla.",
+ "reindexNow": {
+ "label": "Uudelleenindeksoi nyt",
+ "desc": "Uudelleindeksointi luo uudelleen upotukset kaikille seuratuille objekteille. Tämä prosessi suoritetaan taustalla ja voi kuormittaa prosessorin maksimiin ja viedä melko paljon aikaa riippuen seurattujen objektien määrästä.",
+ "confirmTitle": "Vahvista uudelleenindeksointi"
+ }
+ },
+ "faceRecognition": {
+ "title": "Kasvojentunnistus",
+ "desc": "Kasvojentunnistuksen avulla ihmisille voidaan antaa nimiä, ja kun heidän kasvonsa tunnistetaan, Frigate lisää henkilön nimen alaluokaksi. Nämä tiedot näkyvät käyttöliittymässä, suodattimissa ja ilmoituksissa.",
+ "modelSize": {
+ "label": "Mallin koko",
+ "desc": "Kasvojentunnistuksessa käytettävän mallin koko.",
+ "small": {
+ "title": "pieni",
+ "desc": "pieni käyttää FaceNet-kasvojen upotusmallia, joka toimii tehokkaasti useimmilla suorittimilla."
+ },
+ "large": {
+ "title": "suuri",
+ "desc": "suuri käyttää ArcFace-kasvojen upotusmallia ja toimii automaattisesti GPU:lla, jos se on mahdollista."
+ }
+ }
+ },
+ "licensePlateRecognition": {
+ "title": "Rekisterikilven tunnistaminen"
+ }
}
}
diff --git a/web/public/locales/fi/views/system.json b/web/public/locales/fi/views/system.json
index 5000e45c6..04952692e 100644
--- a/web/public/locales/fi/views/system.json
+++ b/web/public/locales/fi/views/system.json
@@ -55,6 +55,13 @@
},
"closeInfo": {
"label": "Sulje GPU:n tiedot"
+ },
+ "nvidiaSMIOutput": {
+ "driver": "Ajuri: {{driver}}",
+ "title": "Nvidia SMI tuloste",
+ "name": "Nimi: {{name}}",
+ "cudaComputerCapability": "CUDA laskentakapasiteetti: {{cuda_compute}}",
+ "vbios": "VBios-tiedot: {{vbios}}"
}
}
},
diff --git a/web/public/locales/fr/audio.json b/web/public/locales/fr/audio.json
index b773f026b..b34615853 100644
--- a/web/public/locales/fr/audio.json
+++ b/web/public/locales/fr/audio.json
@@ -1,10 +1,10 @@
{
- "speech": "Conversation",
+ "speech": "Parole",
"babbling": "Babillage",
- "yell": "Crier",
+ "yell": "Cri",
"bicycle": "Vélo",
"car": "Voiture",
- "bellow": "Ci-dessous",
+ "bellow": "Beuglement",
"whispering": "Chuchotement",
"laughter": "Rires",
"snicker": "Ricanement",
@@ -13,7 +13,7 @@
"bus": "Bus",
"train": "Train",
"motorcycle": "Moto",
- "whoop": "Cri",
+ "whoop": "Cri strident",
"sigh": "Soupir",
"singing": "Chant",
"choir": "Chorale",
@@ -22,7 +22,7 @@
"mantra": "Mantra",
"child_singing": "Chant d'enfant",
"bird": "Oiseau",
- "cat": "chat",
+ "cat": "Chat",
"synthetic_singing": "Chant synthétique",
"rapping": "Rap",
"horse": "Cheval",
@@ -31,15 +31,15 @@
"whistling": "Sifflement",
"breathing": "Respiration",
"snoring": "Ronflement",
- "gasp": "Souffle",
+ "gasp": "Souffle coupé",
"pant": "halètement",
- "snort": "Reniflement",
+ "snort": "Ébrouement",
"camera": "Caméra",
- "cough": "Toussotement",
+ "cough": "Toux",
"groan": "Gémissement",
"grunt": "Grognement",
- "throat_clearing": "Éclaircissement de la gorge",
- "wheeze": "Respiration bruyante",
+ "throat_clearing": "Raclement de gorge",
+ "wheeze": "Respiration sifflante",
"sneeze": "Éternuement",
"sniff": "Reniflement",
"chewing": "Mastication",
@@ -72,7 +72,7 @@
"burping": "Rots",
"fart": "Pet",
"crowd": "Foule",
- "children_playing": "Enfants en train de jouer",
+ "children_playing": "Jeux d'enfants",
"animal": "Animal",
"bark": "Aboiement",
"pig": "Cochon",
@@ -80,7 +80,7 @@
"chicken": "Poulet",
"turkey": "Dinde",
"duck": "Canard",
- "goose": "Dindon",
+ "goose": "Oie",
"wild_animals": "Animaux Sauvages",
"crow": "Corbeau",
"dogs": "Chiens",
@@ -99,31 +99,31 @@
"vehicle": "Véhicule",
"skateboard": "Skateboard",
"door": "Porte",
- "blender": "Mixer",
- "hair_dryer": "Sèche cheveux",
+ "blender": "Mixeur",
+ "hair_dryer": "Sèche-cheveux",
"toothbrush": "Brosse à dents",
- "sink": "Lavabo",
- "scissors": "Paire de ciseaux",
+ "sink": "Évier",
+ "scissors": "Ciseaux",
"humming": "Bourdonnement",
- "shuffle": "Mélanger",
- "footsteps": "Pas",
+ "shuffle": "Pas traînants",
+ "footsteps": "Bruits de pas",
"hiccup": "Hoquet",
"finger_snapping": "Claquement de doigts",
"clapping": "Claquements",
"applause": "Applaudissements",
"heartbeat": "Battements de coeur",
- "cheering": "Applaudissement",
+ "cheering": "Acclamations",
"electric_shaver": "Rasoir électrique",
"truck": "Camion",
- "run": "Démarrer",
+ "run": "Course",
"biting": "Mordre",
"stomach_rumble": "Gargouillements d'estomac",
"hands": "Mains",
"heart_murmur": "Souffle au cœur",
- "chatter": "Bavarder",
+ "chatter": "Bavardage",
"pets": "Animaux de compagnie",
- "yip": "Ouais",
- "howl": "Hurler",
+ "yip": "Jappement",
+ "howl": "Hurlement",
"growling": "Grondement",
"whimper_dog": "Gémissements de chien",
"purr": "Ronronnements",
@@ -132,8 +132,8 @@
"livestock": "Bétail",
"neigh": "Hennissement",
"quack": "Coin-coin",
- "honk": "Klaxon",
- "roaring_cats": "Feulements",
+ "honk": "Cacardement",
+ "roaring_cats": "Rugissement de félins",
"roar": "Rugissements",
"chirp": "Gazouillis",
"squawk": "Braillement",
@@ -191,7 +191,7 @@
"steelpan": "Pan",
"orchestra": "Orchestre",
"brass_instrument": "Cuivres",
- "french_horn": "Cor français",
+ "french_horn": "Cor d'harmonie",
"trumpet": "Trompette",
"bowed_string_instrument": "Instrument à cordes frottées",
"string_section": "Section des cordes",
@@ -247,7 +247,7 @@
"sad_music": "Musique triste",
"tender_music": "Musique tendre",
"exciting_music": "Musique stimulante",
- "angry_music": "Musique énervée",
+ "angry_music": "Musique agressive",
"scary_music": "Musique effrayante",
"wind": "Vent",
"rustling_leaves": "Bruissements de feuilles",
@@ -277,7 +277,7 @@
"skidding": "Dérapage",
"tire_squeal": "Crissements de pneu",
"car_passing_by": "Passage de voiture",
- "race_car": "Course de voitures",
+ "race_car": "Voiture de course",
"air_brake": "Frein pneumatique",
"air_horn": "Klaxon à air",
"reversing_beeps": "Bips de marche arrière",
@@ -311,7 +311,7 @@
"squeak": "Grincement",
"cupboard_open_or_close": "Ouverture ou fermeture de placard",
"drawer_open_or_close": "Ouverture ou fermeture de tiroir",
- "dishes": "Plats",
+ "dishes": "Bruit de vaisselle",
"cutlery": "Couverts",
"chopping": "Hacher",
"frying": "Friture",
@@ -324,7 +324,7 @@
"zipper": "Fermeture éclair",
"keys_jangling": "Tintements de clés",
"coin": "Pièce de monnaie",
- "shuffling_cards": "Mélange de cartes",
+ "shuffling_cards": "Battement de cartes",
"typing": "Frappe au clavier",
"typewriter": "Machine à écrire",
"writing": "Écriture",
@@ -414,16 +414,90 @@
"idling": "Ralenti",
"radio": "Radio",
"telephone": "Téléphone",
- "bow_wow": "Ouaf ouaf",
+ "bow_wow": "Aboiement",
"hiss": "Sifflement",
"clip_clop": "Clic-clac",
"cattle": "Bétail",
"moo": "Meuglement",
"cowbell": "Clochette",
"oink": "Grouin-grouin",
- "bleat": "Bêler",
+ "bleat": "Bêlement",
"fowl": "Volaille",
"cluck": "Gloussement",
"cock_a_doodle_doo": "Cocorico",
- "gobble": "Glouglou"
+ "gobble": "Glouglou",
+ "chird": "Accord",
+ "change_ringing": "Carillon de cloches",
+ "sodeling": "Sodèle",
+ "shofar": "Choffar",
+ "liquid": "Liquide",
+ "splash": "Éclaboussure",
+ "slosh": "Clapotis",
+ "squish": "Bruit de pataugeage",
+ "drip": "Goutte à goutte",
+ "trickle": "Filet",
+ "gush": "Jet",
+ "fill": "Remplir",
+ "spray": "Pulvérisation",
+ "pump": "Pompe",
+ "stir": "Remuer",
+ "boiling": "Ébullition",
+ "arrow": "Flèche",
+ "pour": "Verser",
+ "sonar": "Sonar",
+ "whoosh": "Whoosh",
+ "thump": "Coup sourd",
+ "thunk": "Bruit sourd",
+ "electronic_tuner": "Accordeur électronique",
+ "effects_unit": "Unité d'effets",
+ "chorus_effect": "Effet de chœur",
+ "basketball_bounce": "Rebond de basket-ball",
+ "bang": "Détonation",
+ "slap": "Gifle",
+ "whack": "Coup sec",
+ "smash": "Fracasser",
+ "breaking": "Bruit de casse",
+ "bouncing": "Rebondissement",
+ "whip": "Fouet",
+ "flap": "Battement",
+ "scratch": "Grattement",
+ "scrape": "Raclement",
+ "rub": "Frottement",
+ "roll": "Roulement",
+ "crushing": "Écrasement",
+ "crumpling": "Froissement",
+ "tearing": "Déchirure",
+ "beep": "Bip",
+ "ping": "Ping",
+ "ding": "Ding",
+ "clang": "Bruit métallique",
+ "squeal": "Grincement",
+ "creak": "Craquer",
+ "rustle": "Bruissement",
+ "whir": "Vrombissement",
+ "clatter": "Bruit",
+ "sizzle": "Grésillement",
+ "clicking": "Cliquetis",
+ "clickety_clack": "Clic-clac",
+ "rumble": "Grondement",
+ "plop": "Ploc",
+ "hum": "Hum",
+ "harmonic": "Harmonique",
+ "outside": "Extérieur",
+ "reverberation": "Réverbération",
+ "echo": "Écho",
+ "distortion": "Distorsion",
+ "vibration": "Vibration",
+ "zing": "Sifflement",
+ "crunch": "Croque",
+ "sine_wave": "Onde sinusoïdale",
+ "chirp_tone": "Gazouillis",
+ "pulse": "Impulsion",
+ "inside": "Intérieur",
+ "noise": "Bruit",
+ "mains_hum": "Bourdonnement du secteur",
+ "sidetone": "Retour de voix",
+ "cacophony": "Cacophonie",
+ "throbbing": "Pulsation",
+ "boing": "Boing"
}
diff --git a/web/public/locales/fr/common.json b/web/public/locales/fr/common.json
index 5ed9f65a9..39820367c 100644
--- a/web/public/locales/fr/common.json
+++ b/web/public/locales/fr/common.json
@@ -1,6 +1,6 @@
{
"time": {
- "untilForRestart": "Jusqu'au redémarrage de Frigate.",
+ "untilForRestart": "Jusqu'au redémarrage de Frigate",
"untilRestart": "Jusqu'au redémarrage",
"untilForTime": "Jusqu'à {{time}}",
"justNow": "À l'instant",
@@ -22,10 +22,10 @@
"pm": "PM",
"am": "AM",
"yr": "{{time}} a",
- "year_one": "{{time}} année",
- "year_many": "{{time}} années",
- "year_other": "{{time}} années",
- "mo": "{{time}} m",
+ "year_one": "{{time}} an",
+ "year_many": "{{time}} ans",
+ "year_other": "{{time}} ans",
+ "mo": "{{time}} mois",
"month_one": "{{time}} mois",
"month_many": "{{time}} mois",
"month_other": "{{time}} mois",
@@ -33,7 +33,7 @@
"second_one": "{{time}} seconde",
"second_many": "{{time}} secondes",
"second_other": "{{time}} secondes",
- "m": "{{time}} mn",
+ "m": "{{time}} min",
"hour_one": "{{time}} heure",
"hour_many": "{{time}} heures",
"hour_other": "{{time}} heures",
@@ -65,29 +65,33 @@
},
"formattedTimestampHourMinute": {
"24hour": "HH:mm",
- "12hour": "HH:mm aaa"
+ "12hour": "HH:mm"
},
"formattedTimestampMonthDay": "d MMM",
"formattedTimestampFilename": {
- "12hour": "dd-MM-yy-HH-mm-ss-a",
+ "12hour": "dd-MM-yy-HH-mm-ss",
"24hour": "dd-MM-yy-HH-mm-ss"
},
"formattedTimestampMonthDayHourMinute": {
- "12hour": "d MMM, HH:mm aaa",
+ "12hour": "d MMM, HH:mm",
"24hour": "d MMM, HH:mm"
},
"formattedTimestampHourMinuteSecond": {
"24hour": "HH:mm:ss",
- "12hour": "HH:mm:ss aaa"
+ "12hour": "HH:mm:ss"
},
"formattedTimestampMonthDayYearHourMinute": {
- "12hour": "d MMM yyyy, HH:mm aaa",
+ "12hour": "d MMM yyyy, HH:mm",
"24hour": "d MMM yyyy, HH:mm"
},
"formattedTimestampMonthDayYear": {
"12hour": "d MMM, yyyy",
"24hour": "d MMM,yyyy"
- }
+ },
+ "inProgress": "En cours",
+ "invalidStartTime": "Heure de début invalide",
+ "invalidEndTime": "Heure de fin invalide",
+ "never": "Jamais"
},
"button": {
"apply": "Appliquer",
@@ -98,16 +102,16 @@
"close": "Fermer",
"copy": "Copier",
"back": "Retour",
- "history": "Historique",
- "pictureInPicture": "Image en incrustation",
+ "history": "Chronologie",
+ "pictureInPicture": "Image dans l'image",
"twoWayTalk": "Conversation bidirectionnelle",
- "off": "Inactif",
- "edit": "Editer",
+ "off": "OFF",
+ "edit": "Modifier",
"copyCoordinates": "Copier les coordonnées",
"delete": "Supprimer",
"yes": "Oui",
"no": "Non",
- "unsuspended": "Reprendre",
+ "unsuspended": "Réactiver",
"play": "Lire",
"unselect": "Désélectionner",
"suspended": "Suspendu",
@@ -120,11 +124,12 @@
"next": "Suivant",
"exitFullscreen": "Sortir du mode plein écran",
"cameraAudio": "Son de la caméra",
- "on": "Actif",
+ "on": "ON",
"export": "Exporter",
"deleteNow": "Supprimer maintenant",
"download": "Télécharger",
- "done": "Terminé"
+ "done": "Terminé",
+ "continue": "Continuer"
},
"menu": {
"configuration": "Configuration",
@@ -142,14 +147,14 @@
"nl": "Nederlands (Néerlandais)",
"sv": "Svenska (Suédois)",
"cs": "Čeština (Tchèque)",
- "nb": "Norsk Bokmål (Bokmål Norvégien)",
+ "nb": "Norsk Bokmål (Norvégien Bokmål)",
"ko": "한국어 (Coréen)",
- "fa": "فارسی (Perse)",
+ "fa": "فارسی (Persan)",
"pl": "Polski (Polonais)",
"el": "Ελληνικά (Grec)",
"ro": "Română (Roumain)",
"hu": "Magyar (Hongrois)",
- "he": "עברית (Hebreu)",
+ "he": "עברית (Hébreu)",
"ru": "Русский (Russe)",
"de": "Deutsch (Allemand)",
"es": "Español (Espagnol)",
@@ -162,7 +167,16 @@
"vi": "Tiếng Việt (Vietnamien)",
"yue": "粵語 (Cantonais)",
"th": "ไทย (Thai)",
- "ca": "Català (Catalan)"
+ "ca": "Català (Catalan)",
+ "ptBR": "Português brasileiro (Portugais brésilien)",
+ "sr": "Српски (Serbe)",
+ "sl": "Slovenščina (Slovène)",
+ "lt": "Lietuvių (Lithuanien)",
+ "bg": "Български (Bulgare)",
+ "gl": "Galego (Galicien)",
+ "id": "Bahasa Indonesia (Indonésien)",
+ "ur": "اردو (Ourdou)",
+ "hr": "Hrvatski (Croate)"
},
"appearance": "Apparence",
"darkMode": {
@@ -173,7 +187,7 @@
},
"label": "Mode sombre"
},
- "review": "Revue d'événements",
+ "review": "Activités",
"explore": "Explorer",
"export": "Exporter",
"user": {
@@ -191,18 +205,18 @@
},
"system": "Système",
"help": "Aide",
- "configurationEditor": "Editeur de configuration",
+ "configurationEditor": "Éditeur de configuration",
"theme": {
"contrast": "Contraste élevé",
"blue": "Bleu",
"green": "Vert",
"nord": "Nord",
"red": "Rouge",
- "default": "Défaut",
+ "default": "Par défaut",
"label": "Thème",
"highcontrast": "Contraste élevé"
},
- "systemMetrics": "Indicateurs systèmes",
+ "systemMetrics": "Métriques du système",
"settings": "Paramètres",
"withSystem": "Système",
"restart": "Redémarrer Frigate",
@@ -216,25 +230,26 @@
"allCameras": "Toutes les caméras",
"title": "Direct"
},
- "uiPlayground": "Gestion de l'interface",
+ "uiPlayground": "Bac à sable de l'interface",
"faceLibrary": "Bibliothèque de visages",
- "languages": "Langues"
+ "languages": "Langues",
+ "classification": "Classification"
},
"toast": {
"save": {
"title": "Enregistrer",
"error": {
"noMessage": "Echec lors de l'enregistrement des changements de configuration",
- "title": "Echec lors de l'enregistrement des changements de configuration : {{errorMessage}}"
+ "title": "Échec de l'enregistrement des changements de configuration : {{errorMessage}}"
}
},
- "copyUrlToClipboard": "Lien copié dans le presse-papier."
+ "copyUrlToClipboard": "URL copiée dans le presse-papiers"
},
"role": {
"title": "Rôle",
"viewer": "Observateur",
"admin": "Administrateur",
- "desc": "Les administrateurs accèdent à l'ensemble des fonctionnalités de l'interface Frigate. Les observateurs sont limités à la consultation des caméras, de la revue d'événements, et à l'historique des enregistrements dans l'interface utilisateur."
+ "desc": "Les administrateurs ont un accès complet à toutes les fonctionnalités de l'interface Frigate. Les observateurs sont limités à la consultation des caméras, des activités, et à l'historique des enregistrements dans l'interface."
},
"pagination": {
"next": {
@@ -254,13 +269,20 @@
"desc": "Page non trouvée"
},
"selectItem": "Sélectionner {{item}}",
+ "readTheDocumentation": "Lire la documentation",
"accessDenied": {
"title": "Accès refusé",
"documentTitle": "Accès refusé - Frigate",
- "desc": "Vous n'avez pas l'autorisation de voir cette page."
+ "desc": "Vous n'avez pas l'autorisation de consulter cette page."
},
"label": {
- "back": "Retour"
+ "back": "Retour",
+ "hide": "Masquer {{item}}",
+ "show": "Afficher {{item}}",
+ "ID": "ID",
+ "none": "Aucun",
+ "all": "Tous",
+ "other": "Autre"
},
"unit": {
"speed": {
@@ -270,6 +292,26 @@
"length": {
"feet": "pieds",
"meters": "mètres"
+ },
+ "data": {
+ "kbps": "ko/s",
+ "mbps": "Mo/s",
+ "gbps": "Go/s",
+ "kbph": "ko/heure",
+ "mbph": "Mo/heure",
+ "gbph": "Go/heure"
}
+ },
+ "information": {
+ "pixels": "{{area}}px"
+ },
+ "field": {
+ "optional": "Facultatif",
+ "internalID": "L'ID interne utilisée par Frigate dans la configuration et la base de donnêes"
+ },
+ "list": {
+ "two": "{{0}} et {{1}}",
+ "many": "{{items}}, et {{last}}",
+ "separatorWithSpace": ", "
}
}
diff --git a/web/public/locales/fr/components/auth.json b/web/public/locales/fr/components/auth.json
index 65e26691b..3e600fb71 100644
--- a/web/public/locales/fr/components/auth.json
+++ b/web/public/locales/fr/components/auth.json
@@ -1,15 +1,16 @@
{
"form": {
"password": "Mot de passe",
- "login": "Identifiant",
+ "login": "Connexion",
"user": "Nom d'utilisateur",
"errors": {
"unknownError": "Erreur inconnue. Vérifiez les journaux.",
"webUnknownError": "Erreur inconnue. Vérifiez les journaux de la console.",
- "passwordRequired": "Un mot de passe est requis",
+ "passwordRequired": "Mot de passe est requis",
"loginFailed": "Échec de l'authentification",
- "usernameRequired": "Un nom d'utilisateur est requis",
- "rateLimit": "Nombre d'essais dépassé. Réessayez plus tard."
- }
+ "usernameRequired": "Nom d'utilisateur requis",
+ "rateLimit": "Trop de tentatives. Veuillez réessayer plus tard."
+ },
+ "firstTimeLogin": "Première connexion ? Vos identifiants se trouvent dans les journaux de Frigate."
}
}
diff --git a/web/public/locales/fr/components/camera.json b/web/public/locales/fr/components/camera.json
index 582b211b5..0e95c70e3 100644
--- a/web/public/locales/fr/components/camera.json
+++ b/web/public/locales/fr/components/camera.json
@@ -1,38 +1,38 @@
{
"group": {
- "edit": "Éditer le groupe de caméras",
- "label": "Groupe de caméras",
+ "edit": "Modifier le groupe de caméras",
+ "label": "Groupes de caméras",
"add": "Ajouter un groupe de caméras",
"delete": {
"label": "Supprimer le groupe de caméras",
"confirm": {
- "title": "Confirmer la suppression",
+ "title": "Confirmez la suppression",
"desc": "Êtes-vous sûr de vouloir supprimer le groupe de caméras {{name}} ?"
}
},
"name": {
- "placeholder": "Saisissez un nom…",
+ "placeholder": "Saisissez un nom.",
"label": "Nom",
"errorMessage": {
"mustLeastCharacters": "Le nom du groupe de caméras doit comporter au moins 2 caractères.",
"exists": "Le nom du groupe de caméras existe déjà.",
- "nameMustNotPeriod": "Le nom de groupe de caméras ne doit pas contenir de période.",
- "invalid": "Nom de groupe de caméras invalide."
+ "nameMustNotPeriod": "Le nom de groupe de caméras ne doit pas contenir de point.",
+ "invalid": "Nom de groupe de caméras invalide"
}
},
"cameras": {
"label": "Caméras",
- "desc": "Sélectionner les caméras pour ce groupe."
+ "desc": "Sélectionnez les caméras pour ce groupe."
},
"success": "Le groupe de caméras ({{name}}) a été enregistré.",
"icon": "Icône",
"camera": {
"setting": {
- "label": "Paramètres de flux de caméra",
- "title": "Paramètres de flux de {{cameraName}}",
- "audioIsUnavailable": "L'audio n'est pas disponible pour ce flux",
- "audioIsAvailable": "L'audio est disponible pour ce flux",
- "desc": "Modifie les options du flux temps réel pour le tableau de bord de ce groupe de caméras. Ces paramètres sont spécifiques à un périphérique et/ou navigateur.",
+ "label": "Paramètres du flux de la caméra",
+ "title": "Paramètres du flux de {{cameraName}}",
+ "audioIsUnavailable": "L'audio n'est pas disponible pour ce flux.",
+ "audioIsAvailable": "L'audio est disponible pour ce flux.",
+ "desc": "Modifier les options du flux temps réel pour le tableau de bord de ce groupe de caméras. Ces paramètres sont spécifiques à l'appareil ou au navigateur.",
"audio": {
"tips": {
"document": "Lire la documentation ",
@@ -40,33 +40,34 @@
}
},
"streamMethod": {
- "label": "Méthode de streaming",
+ "label": "Méthode de diffusion",
"method": {
"noStreaming": {
- "label": "Pas de diffusion",
- "desc": "Les images provenant de la caméra ne seront mises à jour qu'une fois par minute et il n'y aura pas de diffusion en direct."
+ "label": "Aucune diffusion",
+ "desc": "Les images provenant de la caméra ne seront mises à jour qu'une fois par minute et il n'y aura aucune diffusion en direct."
},
"smartStreaming": {
- "label": "Diffusion intelligente (recommandé)",
- "desc": "La diffusion intelligente mettra à jour les images de la caméra une fois par minute lorsqu'aucune activité n'est détectée afin de conserver la bande-passante et les ressources. Quand une activité est détectée, le flux bascule automatiquement en diffusion temps réel."
+ "label": "Diffusion intelligente (recommandée)",
+ "desc": "La diffusion intelligente mettra à jour l'image de la caméra une fois par minute lorsqu'aucune activité n'est détectée, afin de préserver la bande passante et les ressources. Quand une activité est détectée, l'image bascule automatiquement en flux temps réel."
},
"continuousStreaming": {
"label": "Diffusion en continu",
"desc": {
"title": "L'image de la caméra sera toujours un flux temps réel lorsqu'elle est visible dans le tableau de bord, même si aucune activité n'est détectée.",
- "warning": "La diffusion en continu peut engendrer une bande-passante élevée et des problèmes de performance. A utiliser avec précaution."
+ "warning": "La diffusion en continu peut entraîner une consommation de bande passante élevée et des problèmes de performance. À utiliser avec prudence."
}
}
},
- "placeholder": "Choisissez une méthode de diffusion"
+ "placeholder": "Choisissez une méthode de diffusion."
},
"compatibilityMode": {
"label": "Mode de compatibilité",
- "desc": "Activer cette option uniquement si votre flux temps réel affiche des erreurs chromatiques et a une ligne diagonale sur le côté droit de l'image."
+ "desc": "Activez cette option uniquement si votre flux temps réel affiche des artefacts chromatiques et présente une ligne diagonale sur le côté droit de l'image."
},
"stream": "Flux",
- "placeholder": "Choisissez un flux"
- }
+ "placeholder": "Choisissez un flux."
+ },
+ "birdseye": "Birdseye"
}
},
"debug": {
@@ -79,7 +80,7 @@
"label": "Paramètres",
"hideOptions": "Masquer les options"
},
- "boundingBox": "Boîte de délimitation",
+ "boundingBox": "Cadre de détection",
"zones": "Zones",
"regions": "Régions"
}
diff --git a/web/public/locales/fr/components/dialog.json b/web/public/locales/fr/components/dialog.json
index d92e3ff72..f0b542b70 100644
--- a/web/public/locales/fr/components/dialog.json
+++ b/web/public/locales/fr/components/dialog.json
@@ -2,8 +2,8 @@
"restart": {
"title": "Êtes-vous sûr de vouloir redémarrer Frigate ?",
"restarting": {
- "title": "Frigate redémarre",
- "content": "Actualisation de la page dans {{countdown}} secondes.",
+ "title": "Redémarrage de Frigate en cours",
+ "content": "Cette page sera rechargée dans {{countdown}} secondes.",
"button": "Forcer l'actualisation maintenant"
},
"button": "Redémarrer"
@@ -31,10 +31,10 @@
"submitted": "Soumis"
},
"question": {
- "label": "Confirmez ce libellé pour Frigate+",
- "ask_an": "Est-ce que cet objet est un(e) {{label}} ?",
- "ask_a": "Est-ce que cet objet est un(e) {{label}} ?",
- "ask_full": "Est-ce-que cet objet est un(e) {{translatedLabel}} ?"
+ "label": "Confirmez cette étiquette pour Frigate+.",
+ "ask_an": "Cet objet est-il un(e) {{label}} ?",
+ "ask_a": "Cet objet est-il un(e) {{label}} ?",
+ "ask_full": "Cet objet est-il un(e) {{translatedLabel}} ?"
}
}
},
@@ -61,25 +61,26 @@
"selectOrExport": "Sélectionner ou exporter",
"toast": {
"error": {
- "failed": "Échec du démarrage de l'export : {{error}}",
- "endTimeMustAfterStartTime": "L'heure de fin doit être postérieure à l'heure de début",
- "noVaildTimeSelected": "La plage horaire sélectionnée n'est pas valide"
+ "failed": "Échec du démarrage de l'exportation : {{error}}",
+ "endTimeMustAfterStartTime": "L'heure de fin doit être postérieure à l'heure de début.",
+ "noVaildTimeSelected": "La plage horaire sélectionnée n'est pas valide."
},
- "success": "Exportation démarrée avec succès. Consultez le fichier dans le dossier /exports."
+ "success": "Exportation démarrée avec succès. Consultez le fichier sur la page des exportations.",
+ "view": "Vue"
},
"select": "Sélectionner",
"name": {
- "placeholder": "Nommer l'export"
+ "placeholder": "Nommer l'exportation"
},
"export": "Exporter",
"fromTimeline": {
- "saveExport": "Enregistrer l'export",
- "previewExport": "Prévisualiser l'export"
+ "saveExport": "Enregistrer l'exportation",
+ "previewExport": "Aperçu de l'exportation"
}
},
"search": {
"saveSearch": {
- "desc": "Donnez un nom à cette recherche enregistrée.",
+ "desc": "Saisissez un nom pour cette recherche enregistrée.",
"label": "Enregistrer la recherche",
"success": "La recherche ({{searchName}}) a été enregistrée.",
"button": {
@@ -88,7 +89,7 @@
}
},
"overwrite": "{{searchName}} existe déjà. L'enregistrement écrasera la recherche existante.",
- "placeholder": "Saisissez un nom pour votre recherche"
+ "placeholder": "Saisissez un nom pour votre recherche."
}
},
"streaming": {
@@ -102,25 +103,34 @@
},
"showStats": {
"label": "Afficher les statistiques du flux",
- "desc": "Activez cette option pour montrer les statistiques de diffusion en incrustation sur le flux vidéo de la caméra."
+ "desc": "Activez cette option pour afficher les statistiques de diffusion en incrustation sur le flux vidéo de la caméra."
},
"debugView": "Affichage de débogage"
},
"recording": {
"confirmDelete": {
"desc": {
- "selected": "Êtes-vous sûr(e) de vouloir supprimer toutes les vidéos enregistrées associées à cet élément de la revue d'événements ? détection de la caméra {{cameraName}}. Vérifiez le journal d'erreurs."
},
- "livePlayerRequiredIOSVersion": "iOS 17.1 ou une version supérieure est requis pour ce type de flux en direct.",
- "cameraDisabled": "La caméra est désactivée",
+ "livePlayerRequiredIOSVersion": "iOS 17.1 ou une version supérieure est requise pour ce type de flux en direct.",
+ "cameraDisabled": "La caméra est désactivée.",
"stats": {
"streamType": {
"title": "Type de flux :",
@@ -37,7 +37,7 @@
"title": "Images perdues :"
},
"decodedFrames": "Images décodées :",
- "droppedFrameRate": "Proportion d'images perdues :",
+ "droppedFrameRate": "Taux d'images perdues :",
"totalFrames": "Total images :"
},
"toast": {
diff --git a/web/public/locales/fr/objects.json b/web/public/locales/fr/objects.json
index d959a8e42..9c9d5a6cf 100644
--- a/web/public/locales/fr/objects.json
+++ b/web/public/locales/fr/objects.json
@@ -9,17 +9,17 @@
"boat": "Bateau",
"traffic_light": "Feu de circulation",
"fire_hydrant": "Bouche d'incendie",
- "street_sign": "Plaque de rue",
+ "street_sign": "Panneau de signalisation",
"parking_meter": "Parcmètre",
"bench": "Banc",
"bird": "Oiseau",
- "cat": "chat",
+ "cat": "Chat",
"stop_sign": "Panneau de stop",
"dog": "Chien",
"horse": "Cheval",
"sheep": "Mouton",
"cow": "Vache",
- "elephant": "Eléphant",
+ "elephant": "Éléphant",
"bear": "Ours",
"zebra": "Zèbre",
"hat": "Chapeau",
@@ -27,10 +27,10 @@
"suitcase": "Valise",
"frisbee": "Frisbee",
"skis": "Skis",
- "snowboard": "Surf des neiges",
- "sports_ball": "Ballon des sports",
+ "snowboard": "Snowboard",
+ "sports_ball": "Ballon de sport",
"kite": "Cerf-volant",
- "baseball_bat": "Batte de base-ball",
+ "baseball_bat": "Batte de baseball",
"umbrella": "Parapluie",
"giraffe": "Girafe",
"eye_glasses": "Lunettes",
@@ -42,7 +42,7 @@
"baseball_glove": "Gant de baseball",
"skateboard": "Skateboard",
"surfboard": "Planche de surf",
- "tennis_racket": "Raquette de Tennis",
+ "tennis_racket": "Raquette de tennis",
"plate": "Assiette",
"cup": "Tasse",
"banana": "Banane",
@@ -63,7 +63,7 @@
"toaster": "Grille-pain",
"book": "Livre",
"teddy_bear": "Ours en peluche",
- "blender": "Mixer",
+ "blender": "Mixeur",
"toothbrush": "Brosse à dents",
"hair_brush": "Brosse à cheveux",
"vehicle": "Véhicule",
@@ -92,7 +92,7 @@
"refrigerator": "Réfrigérateur",
"bark": "Aboiement",
"oven": "Four",
- "scissors": "Paire de ciseaux",
+ "scissors": "Ciseaux",
"toilet": "Toilettes",
"carrot": "Carotte",
"bed": "Lit",
@@ -100,11 +100,11 @@
"fork": "Fourchette",
"squirrel": "Écureuil",
"microwave": "Micro-ondes",
- "hair_dryer": "Sèche cheveux",
+ "hair_dryer": "Sèche-cheveux",
"bowl": "Bol",
"spoon": "Cuillère",
"sandwich": "Sandwich",
- "sink": "Lavabo",
+ "sink": "Évier",
"broccoli": "Brocoli",
"knife": "Couteau",
"nzpost": "NZPost",
diff --git a/web/public/locales/fr/views/classificationModel.json b/web/public/locales/fr/views/classificationModel.json
new file mode 100644
index 000000000..0926f4cd6
--- /dev/null
+++ b/web/public/locales/fr/views/classificationModel.json
@@ -0,0 +1,193 @@
+{
+ "documentTitle": "Modèles de classification - Frigate",
+ "button": {
+ "deleteClassificationAttempts": "Supprimer les images de classification",
+ "renameCategory": "Renommer la classe",
+ "deleteCategory": "Supprimer la classe",
+ "deleteImages": "Supprimer les images",
+ "trainModel": "Entraîner le modèle",
+ "addClassification": "Ajouter une classification",
+ "deleteModels": "Supprimer les modèles",
+ "editModel": "Modifier le modèle"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Classe supprimée",
+ "deletedImage": "Images supprimées",
+ "categorizedImage": "Image classifiée avec succès",
+ "trainedModel": "Modèle entraîné avec succès.",
+ "trainingModel": "L'entraînement du modèle a démarré avec succès.",
+ "deletedModel_one": "{{count}} modèle supprimé avec succès",
+ "deletedModel_many": "{{count}} modèles supprimés avec succès",
+ "deletedModel_other": "{{count}} modèles supprimés avec succès",
+ "updatedModel": "Configuration du modèle mise à jour avec succès",
+ "renamedCategory": "Classe renommée en {{name}} avec succès"
+ },
+ "error": {
+ "deleteImageFailed": "Échec de la suppression : {{errorMessage}}",
+ "deleteCategoryFailed": "Échec de la suppression de la classe : {{errorMessage}}",
+ "categorizeFailed": "Échec de la catégorisation de l'image : {{errorMessage}}",
+ "trainingFailed": "L'entraînement du modèle a échoué. Consultez les journaux de Frigate pour plus de détails.",
+ "deleteModelFailed": "Impossible de supprimer le modèle : {{errorMessage}}",
+ "updateModelFailed": "Impossible de mettre à jour le modèle : {{errorMessage}}",
+ "renameCategoryFailed": "Impossible de renommer la classe : {{errorMessage}}",
+ "trainingFailedToStart": "Impossible de démarrer l'entraînement du modèle : {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Supprimer la classe",
+ "desc": "Êtes-vous sûr de vouloir supprimer la classe {{name}} ? Cette action supprimera définitivement toutes les images associées et nécessitera un réentraînement du modèle.",
+ "minClassesTitle": "Impossible de supprimer la classe",
+ "minClassesDesc": "Un modèle de classification doit avoir au moins 2 classes. Ajoutez une autre classe avant de supprimer celle-ci."
+ },
+ "deleteDatasetImages": {
+ "title": "Supprimer les images du jeu de données",
+ "desc_one": "Êtes-vous sûr de vouloir supprimer {{count}} image du jeu de données {{dataset}} ? Cette action est irréversible et nécessitera un réentraînement du modèle.",
+ "desc_many": "Êtes-vous sûr de vouloir supprimer {{count}} images du jeu de données {{dataset}} ? Cette action est irréversible et nécessitera un réentraînement du modèle.",
+ "desc_other": "Êtes-vous sûr de vouloir supprimer {{count}} images du jeu de données {{dataset}} ? Cette action est irréversible et nécessitera un réentraînement du modèle."
+ },
+ "deleteTrainImages": {
+ "title": "Supprimer les images d'entraînement",
+ "desc_one": "Êtes-vous sûr de vouloir supprimer {{count}} image ? Cette action est irréversible.",
+ "desc_many": "Êtes-vous sûr de vouloir supprimer {{count}} images ? Cette action est irréversible.",
+ "desc_other": "Êtes-vous sûr de vouloir supprimer {{count}} images ? Cette action est irréversible."
+ },
+ "renameCategory": {
+ "title": "Renommer la classe",
+ "desc": "Saisissez un nouveau nom pour {{name}}. Vous devrez réentraîner le modèle pour que le changement de nom prenne effet."
+ },
+ "description": {
+ "invalidName": "Nom invalide. Les noms ne peuvent contenir que des lettres, des chiffres, des espaces, des apostrophes, des traits de soulignement et des tirets."
+ },
+ "train": {
+ "title": "Classifications récentes",
+ "aria": "Sélectionner des classifications récentes",
+ "titleShort": "Récent"
+ },
+ "categories": "Classes",
+ "createCategory": {
+ "new": "Créer une nouvelle classe"
+ },
+ "categorizeImageAs": "Classifier comme :",
+ "categorizeImage": "Classifier l'image",
+ "noModels": {
+ "object": {
+ "title": "Aucun modèle de classification d'objets",
+ "description": "Créer un modèle personnalisé pour classifier les objets détectés",
+ "buttonText": "Créer un modèle d'objets"
+ },
+ "state": {
+ "title": "Aucun modèle de classification d'états",
+ "description": "Créer un modèle personnalisé pour surveiller et classifier les changements d'état dans des zones de caméra spécifiques",
+ "buttonText": "Créer un modèle d'états"
+ }
+ },
+ "wizard": {
+ "title": "Créer une nouvelle classification",
+ "steps": {
+ "nameAndDefine": "Nom et définition",
+ "stateArea": "Zone d'état",
+ "chooseExamples": "Choisir des exemples"
+ },
+ "step1": {
+ "description": "Les modèles d'état surveillent des zones de caméra fixes pour détecter des changements (par ex., porte ouverte/fermée). Les modèles d'objets ajoutent des classifications aux objets détectés (par ex., animaux connus, livreurs, etc.).",
+ "name": "Nom",
+ "namePlaceholder": "Saisissez un nom de modèle.",
+ "type": "Type",
+ "typeState": "État",
+ "typeObject": "Objet",
+ "objectLabel": "Étiquette d'objet",
+ "objectLabelPlaceholder": "Sélectionnez un type d'objet.",
+ "classificationType": "Type de classification",
+ "classificationTypeTip": "En savoir plus sur les types de classification",
+ "classificationTypeDesc": "Les sous-étiquettes ajoutent du texte supplémentaire à l'étiquette d'objet (par ex., « Personne : UPS »). Les attributs sont des métadonnées recherchables stockées séparément dans les métadonnées de l'objet.",
+ "classificationSubLabel": "Sous-étiquette",
+ "classificationAttribute": "Attribut",
+ "classes": "Classes",
+ "classesTip": "En savoir plus sur les classes",
+ "classesStateDesc": "Définissez les différents états que votre zone de caméra peut avoir. Par exemple : « ouvert » et « fermé » pour une porte de garage.",
+ "classesObjectDesc": "Définissez les différentes catégories pour classifier les objets détectés. Par exemple : « livreur », « résident », « inconnu » pour la classification des personnes.",
+ "classPlaceholder": "Saisissez le nom de la classe.",
+ "errors": {
+ "nameRequired": "Le nom du modèle est requis.",
+ "nameLength": "Le nom du modèle ne doit pas dépasser 64 caractères.",
+ "nameOnlyNumbers": "Le nom du modèle ne peut pas contenir uniquement des chiffres.",
+ "classRequired": "Au moins une classe est requise.",
+ "classesUnique": "Les noms de classe doivent être uniques.",
+ "stateRequiresTwoClasses": "Les modèles d'état nécessitent au moins deux classes.",
+ "objectLabelRequired": "Veuillez sélectionner une étiquette d'objet.",
+ "objectTypeRequired": "Veuillez sélectionner un type de classification.",
+ "noneNotAllowed": "La classe 'aucun' n'est pas autorisée."
+ },
+ "states": "États"
+ },
+ "step2": {
+ "description": "Sélectionnez les caméras et définissez la zone à surveiller pour chaque caméra. Le modèle classifiera l'état de ces zones.",
+ "cameras": "Caméras",
+ "selectCamera": "Sélectionner une caméra",
+ "noCameras": "Cliquez sur + pour ajouter des caméras.",
+ "selectCameraPrompt": "Sélectionnez une caméra dans la liste pour définir sa zone de surveillance."
+ },
+ "step3": {
+ "selectImagesPrompt": "Sélectionner toutes les images contenant : {{className}}",
+ "selectImagesDescription": "Cliquez sur les images pour les sélectionner. Cliquez sur Continuer lorsque vous avez terminé avec cette classe.",
+ "generating": {
+ "title": "Génération d'images d'exemple en cours",
+ "description": "Frigate récupère des images représentatives à partir de vos enregistrements. Cela peut prendre un moment..."
+ },
+ "training": {
+ "title": "Entraînement du modèle",
+ "description": "Votre modèle est en cours d'entraînement en arrière-plan. Fermez cette boîte de dialogue. Votre modèle se lancera dès que l'entraînement sera terminé."
+ },
+ "retryGenerate": "Réessayer la génération",
+ "noImages": "Aucune image d'exemple générée",
+ "classifying": "Classification et entraînement en cours...",
+ "trainingStarted": "Entraînement démarré avec succès",
+ "errors": {
+ "noCameras": "Aucune caméra n'est configurée.",
+ "noObjectLabel": "Aucune étiquette d'objet sélectionnée",
+ "generateFailed": "Échec de la génération des exemples : {{error}}",
+ "generationFailed": "Échec de la génération. Veuillez réessayer.",
+ "classifyFailed": "Échec de la classification des images : {{error}}"
+ },
+ "generateSuccess": "Génération des images d'exemple réussie",
+ "allImagesRequired_one": "Veuillez classifier toutes les images. {{count}} image restante.",
+ "allImagesRequired_many": "Veuillez classifier toutes les images. {{count}} images restantes.",
+ "allImagesRequired_other": "Veuillez classifier toutes les images. {{count}} images restantes.",
+ "modelCreated": "Modèle créé avec succès. Utilisez la vue Classifications récentes pour ajouter des images pour les états manquants, puis entraînez le modèle.",
+ "missingStatesWarning": {
+ "title": "Exemples d'états manquants",
+ "description": "Pour des résultats optimaux, il est recommandé de sélectionner des exemples pour tous les états. Vous pouvez continuer sans cette étape, mais le modèle ne sera entraîné que lorsque chaque état disposera d'images. Continuez, puis utilisez la vue Classifications récentes pour classer les images manquantes et lancer l'entraînement."
+ }
+ }
+ },
+ "deleteModel": {
+ "title": "Supprimer le modèle de classification",
+ "single": "Voulez-vous vraiment supprimer {{name}} ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible.",
+ "desc_one": "Voulez-vous vraiment supprimer {{count}} modèle ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible.",
+ "desc_many": "Voulez-vous vraiment supprimer {{count}} modèles ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible.",
+ "desc_other": "Voulez-vous vraiment supprimer {{count}} modèles ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible."
+ },
+ "menu": {
+ "objects": "Objets",
+ "states": "États"
+ },
+ "details": {
+ "scoreInfo": "Le score représente la moyenne de la confiance de classification pour toutes les détections de cet objet.",
+ "none": "Aucun",
+ "unknown": "Inconnu"
+ },
+ "edit": {
+ "title": "Modifier le modèle de classification",
+ "descriptionState": "Modifier les classes pour ce modèle de classification d'état. Les modifications nécessiteront un réentraînement du modèle.",
+ "descriptionObject": "Modifier le type d'objet et le type de classification pour ce modèle de classification d'objet",
+ "stateClassesInfo": "Note : La modification des classes d'état nécessite un réentraînement du modèle avec les classes mises à jour."
+ },
+ "tooltip": {
+ "trainingInProgress": "Modèle en cours d'entraînement",
+ "noNewImages": "Aucune nouvelle image pour l'entraînement. Veuillez d'abord classifier plus d'images dans le jeu de données.",
+ "modelNotReady": "Le modèle n'est pas prêt pour l'entraînement.",
+ "noChanges": "Aucune modification du jeu de données depuis le dernier entraînement"
+ },
+ "none": "Aucun"
+}
diff --git a/web/public/locales/fr/views/configEditor.json b/web/public/locales/fr/views/configEditor.json
index 5f88fb94f..0ab9b2c40 100644
--- a/web/public/locales/fr/views/configEditor.json
+++ b/web/public/locales/fr/views/configEditor.json
@@ -2,7 +2,7 @@
"configEditor": "Éditeur de configuration",
"documentTitle": "Éditeur de configuration - Frigate",
"copyConfig": "Copier la configuration",
- "saveOnly": "Enregistrer seulement",
+ "saveOnly": "Enregistrer uniquement",
"saveAndRestart": "Enregistrer et redémarrer",
"toast": {
"success": {
@@ -12,5 +12,7 @@
"savingError": "Erreur lors de l'enregistrement de la configuration"
}
},
- "confirm": "Quitter sans enregistrer ?"
+ "confirm": "Quitter sans enregistrer ?",
+ "safeConfigEditor": "Éditeur de configuration (mode sans échec)",
+ "safeModeDescription": "Frigate est en mode sans échec en raison d'une erreur de validation de la configuration."
}
diff --git a/web/public/locales/fr/views/events.json b/web/public/locales/fr/views/events.json
index d8d58332c..6baaf9b93 100644
--- a/web/public/locales/fr/views/events.json
+++ b/web/public/locales/fr/views/events.json
@@ -2,22 +2,26 @@
"detections": "Détections",
"motion": {
"label": "Mouvement",
- "only": "Mouvement seulement"
+ "only": "Mouvement uniquement"
},
"alerts": "Alertes",
"allCameras": "Toutes les caméras",
"empty": {
- "alert": "Il n'y a aucune alerte à passer en revue",
- "detection": "Il n'y a aucune détection à passer en revue",
- "motion": "Aucune donnée de mouvement trouvée"
+ "alert": "Aucune alerte à traiter",
+ "detection": "Aucune détection à traiter",
+ "motion": "Aucune donnée de mouvement trouvée",
+ "recordingsDisabled": {
+ "title": "Les enregistrements doivent être activés.",
+ "description": "Les activités ne peuvent être générées pour une caméra que si l'enregistrement est activé pour celle-ci."
+ }
},
"timeline": "Chronologie",
"events": {
"label": "Événements",
"aria": "Sélectionner les événements",
- "noFoundForTimePeriod": "Aucun événement trouvé pour cette plage de temps."
+ "noFoundForTimePeriod": "Aucun événement n'a été trouvé pour cette plage de temps."
},
- "documentTitle": "Revue d'événements -Frigate",
+ "documentTitle": "Activités - Frigate",
"recordings": {
"documentTitle": "Enregistrements - Frigate"
},
@@ -25,15 +29,40 @@
"last24Hours": "Dernières 24 heures"
},
"timeline.aria": "Sélectionner une chronologie",
- "markAsReviewed": "Marqué comme passé en revue",
+ "markAsReviewed": "Marquer comme traitê",
"newReviewItems": {
- "button": "Nouveaux éléments à passer en revue",
- "label": "Afficher les nouveaux éléments de la revue d'événements"
+ "button": "Nouvelles activités à traiter",
+ "label": "Afficher les nouvelles activités"
},
"camera": "Caméra",
- "markTheseItemsAsReviewed": "Marquer ces éléments comme passés en revue",
+ "markTheseItemsAsReviewed": "Marquer ces activités comme traitées",
"selected": "{{count}} sélectionné(s)",
"selected_other": "{{count}} sélectionné(s)",
"selected_one": "{{count}} sélectionné(s)",
- "detected": "détecté"
+ "detected": "détecté",
+ "suspiciousActivity": "Activité suspecte",
+ "threateningActivity": "Activité menaçante",
+ "detail": {
+ "noDataFound": "Aucun détail à traiter",
+ "aria": "Activer/désactiver la vue détaillée",
+ "trackedObject_one": "{{count}} objet",
+ "trackedObject_other": "{{count}} objets",
+ "noObjectDetailData": "Aucun détail d'objet disponible",
+ "label": "Détail",
+ "settings": "Paramètres de la vue Détail",
+ "alwaysExpandActive": {
+ "title": "Toujours développer l'élément actif",
+ "desc": "Toujours développer les détails de l'objet pour l'activité en cours"
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Point suivi",
+ "clickToSeek": "Cliquez pour atteindre ce moment."
+ },
+ "zoomIn": "Zoom avant",
+ "zoomOut": "Zoom arrière",
+ "normalActivity": "Normal",
+ "needsReview": "À traiter",
+ "securityConcern": "Problème de sécurité",
+ "select_all": "Tous"
}
diff --git a/web/public/locales/fr/views/explore.json b/web/public/locales/fr/views/explore.json
index b42cb5f38..637936450 100644
--- a/web/public/locales/fr/views/explore.json
+++ b/web/public/locales/fr/views/explore.json
@@ -5,17 +5,17 @@
"title": "L'exploration est indisponible",
"embeddingsReindexing": {
"estimatedTime": "Temps restant estimé :",
- "finishingShortly": "Termine bientôt",
- "context": "L'exploration peut être utilisée une fois la réindexation des représentations numériques des objets suivis terminée.",
+ "finishingShortly": "Bientôt fini",
+ "context": "L'exploration peut être utilisée une fois la réindexation des embeddings des objets suivis terminée.",
"startingUp": "Démarrage…",
"step": {
- "thumbnailsEmbedded": "Miniatures intégrées : ",
- "descriptionsEmbedded": "Descriptions intégrées : ",
+ "thumbnailsEmbedded": "Embeddings des miniatures : ",
+ "descriptionsEmbedded": "Embeddings des descriptions : ",
"trackedObjectsProcessed": "Objets suivis traités : "
}
},
"downloadingModels": {
- "context": "Frigate télécharge les modèles de représentations numériques nécessaires pour prendre en charge la fonctionnalité de recherche sémantique. Cette opération peut prendre plusieurs minutes selon la vitesse de votre connexion réseau.",
+ "context": "Frigate télécharge les modèles d'embeddings nécessaires pour prendre en charge la fonctionnalité de recherche sémantique. Cette opération peut prendre plusieurs minutes selon la vitesse de votre connexion réseau.",
"setup": {
"visionModelFeatureExtractor": "Extracteur de caractéristiques de modèle de vision",
"textTokenizer": "Tokeniseur de texte",
@@ -24,48 +24,52 @@
},
"tips": {
"documentation": "Lire la documentation",
- "context": "Une fois les modèles téléchargés, il est conseillé de réindexer vos objets suivis."
+ "context": "Une fois les modèles téléchargés, il est conseillé de réindexer les embeddings de vos objets suivis."
},
- "error": "Une erreur est survenue. Vérifier les journaux Frigate."
+ "error": "Une erreur est survenue. Vérifiez les journaux Frigate."
}
},
"details": {
"timestamp": "Horodatage",
"item": {
- "title": "Détails de l'élément de la revue d'événements",
+ "title": "Détails de l'activité",
"button": {
- "share": "Partager cet élément de la revue d'événements",
+ "share": "Partager cette activité",
"viewInExplore": "Afficher dans Explorer"
},
"toast": {
"success": {
"regenerate": "Une nouvelle description a été demandée à {{provider}}. Selon la vitesse de votre fournisseur, la régénération de la nouvelle description peut prendre un certain temps.",
- "updatedSublabel": "Sous-libellé mis à jour avec succès.",
- "updatedLPR": "Plaque d'immatriculation mise à jour avec succès."
+ "updatedSublabel": "Sous-étiquette mise à jour avec succès",
+ "updatedLPR": "Plaque d'immatriculation mise à jour avec succès",
+ "audioTranscription": "Transcription audio demandée avec succès. Selon la vitesse de votre serveur Frigate, la transcription peut prendre un certain temps.",
+ "updatedAttributes": "Attributs mis à jour avec succès"
},
"error": {
"regenerate": "Échec de l'appel de {{provider}} pour une nouvelle description : {{errorMessage}}",
- "updatedSublabelFailed": "Échec de la mise à jour du sous-libellé : {{errorMessage}}",
- "updatedLPRFailed": "Échec de la mise à jour de la plaque d'immatriculation : {{errorMessage}}"
+ "updatedSublabelFailed": "Échec de la mise à jour de la sous-étiquette : {{errorMessage}}",
+ "updatedLPRFailed": "Échec de la mise à jour de la plaque d'immatriculation : {{errorMessage}}",
+ "audioTranscription": "Échec de la demande de transcription audio : {{errorMessage}}",
+ "updatedAttributesFailed": "Échec de la mise à jour des attributs : {{errorMessage}}"
}
},
"tips": {
- "mismatch_one": "{{count}} objet indisponible a été détecté et intégré dans cet élément de la revue d'événements. Cet objet n'a pas été qualifié comme une alerte ou une détection, ou a déjà été nettoyé / supprimé.",
- "mismatch_many": "{{count}} objets indisponibles ont été détectés et intégrés dans cet élément de la revue d'événements. Ces objets n'ont pas été qualifiés comme une alerte ou une détection, ou ont déjà été nettoyés / supprimés.",
- "mismatch_other": "{{count}} objets indisponibles ont été détectés et intégrés dans cet élément de la revue d'événements. Ces objets n'ont pas été qualifiés comme une alerte ou une détection, ou ont déjà été nettoyés / supprimés.",
- "hasMissingObjects": "Ajustez votre configuration si vous souhaitez que Frigate enregistre les objets suivis pour les libellés suivants : {{objects}}"
+ "mismatch_one": "{{count}} objet indisponible a été détecté et intégré dans cette activité. Cet objet n'a pas été qualifié comme une alerte ou une détection, ou a déjà été nettoyé / supprimé.",
+ "mismatch_many": "{{count}} objets indisponibles ont été détectés et intégrés dans cette activité. Ces objets n'ont pas été qualifiés comme une alerte ou une détection, ou ont déjà été nettoyés / supprimés.",
+ "mismatch_other": "{{count}} objets indisponibles ont été détectés et intégrés dans cette activité. Ces objets n'ont pas été qualifiés comme une alerte ou une détection, ou ont déjà été nettoyés / supprimés.",
+ "hasMissingObjects": "Ajustez votre configuration si vous souhaitez que Frigate enregistre les objets suivis pour les étiquettes suivantes : {{objects}}"
},
- "desc": "Détails de l'élément de la revue d'événements"
+ "desc": "Détails de l'activité"
},
- "label": "Libellé",
+ "label": "Étiquette",
"editSubLabel": {
- "title": "Modifier le sous-libellé",
- "desc": "Saisissez un nouveau sous-libellé pour {{label}}",
- "descNoLabel": "Entrer un nouveau sous-libellé pour cet objet suivi"
+ "title": "Modifier la sous-étiquette",
+ "desc": "Saisissez une nouvelle sous-étiquette pour {{label}}.",
+ "descNoLabel": "Saisissez une nouvelle sous-étiquette pour cet objet suivi."
},
"topScore": {
"label": "Meilleur score",
- "info": "Le score le plus élevé est le score médian le plus haut pour l'objet suivi ; il peut donc différer du score affiché sur la miniature du résultat de recherche."
+ "info": "Le meilleur score correspond au score médian le plus élevé de l'objet suivi, il peut donc différer du score affiché sur la miniature du résultat de recherche."
},
"objects": "Objets",
"button": {
@@ -84,8 +88,8 @@
"regenerateFromThumbnails": "Générer à nouveau à partir des miniatures",
"editLPR": {
"title": "Modifier la plaque d'immatriculation",
- "desc": "Saisissez une nouvelle valeur de plaque d'immatriculation pour {{label}}",
- "descNoLabel": "Saisir une nouvelle valeur de plaque d'immatriculation pour cet objet suivi"
+ "desc": "Saisissez une nouvelle valeur de plaque d'immatriculation pour {{label}}.",
+ "descNoLabel": "Saisissez une nouvelle valeur de plaque d'immatriculation pour cet objet suivi."
},
"recognizedLicensePlate": "Plaque d'immatriculation reconnue",
"estimatedSpeed": "Vitesse estimée",
@@ -98,13 +102,26 @@
},
"snapshotScore": {
"label": "Score de l'instantané"
+ },
+ "score": {
+ "label": "Score"
+ },
+ "editAttributes": {
+ "title": "Modifier les attributs",
+ "desc": "Sélectionnez les attributs de classification pour : {{label}}"
+ },
+ "attributes": "Attributs de classification",
+ "title": {
+ "label": "Titre"
}
},
"type": {
"details": "détails",
"video": "vidéo",
"object_lifecycle": "cycle de vie de l'objet",
- "snapshot": "instantané"
+ "snapshot": "instantané",
+ "thumbnail": "Miniature",
+ "tracking_details": "Détails du suivi"
},
"objectLifecycle": {
"title": "Cycle de vie de l'objet",
@@ -115,8 +132,8 @@
"autoTrackingTips": "Les positions des cadres englobants seront imprécises pour les caméras à suivi automatique.",
"lifecycleItemDesc": {
"visible": "{{label}} détecté",
- "entered_zone": "{{label}} est entré dans {{zones}}",
- "stationary": "{{label}} est devenu stationnaire",
+ "entered_zone": "{{label}} est entré dans {{zones}}.",
+ "stationary": "{{label}} est devenu stationnaire.",
"attribute": {
"other": "{{label}} reconnu comme {{attribute}}",
"faceOrLicense_plate": "{{attribute}} détecté pour {{label}}"
@@ -124,7 +141,7 @@
"gone": "{{label}} parti",
"heard": "{{label}} entendu",
"external": "{{label}} détecté",
- "active": "{{label}} est devenu actif",
+ "active": "{{label}} est devenu actif.",
"header": {
"zones": "Zones",
"area": "Aire",
@@ -134,7 +151,7 @@
"annotationSettings": {
"title": "Paramètres d'annotation",
"showAllZones": {
- "title": "Montrer toutes les zones",
+ "title": "Afficher toutes les zones",
"desc": "Afficher systématiquement les zones sur les images quand des objets y sont entrés"
},
"offset": {
@@ -170,8 +187,8 @@
"label": "Visualiser le cycle de vie de l'objet"
},
"viewInHistory": {
- "label": "Afficher dans l'historique",
- "aria": "Afficher dans l'historique"
+ "label": "Afficher dans la chronologie",
+ "aria": "Afficher dans la chronologie"
},
"downloadVideo": {
"label": "Télécharger la vidéo",
@@ -183,12 +200,34 @@
},
"deleteTrackedObject": {
"label": "Supprimer cet objet suivi"
+ },
+ "addTrigger": {
+ "label": "Ajouter un déclencheur",
+ "aria": "Ajouter un déclencheur pour cet objet suivi"
+ },
+ "audioTranscription": {
+ "label": "Transcrire",
+ "aria": "Demander une transcription audio"
+ },
+ "showObjectDetails": {
+ "label": "Afficher le parcours de l'objet"
+ },
+ "hideObjectDetails": {
+ "label": "Masquer le parcours de l'objet"
+ },
+ "viewTrackingDetails": {
+ "label": "Voir les détails du suivi",
+ "aria": "Afficher les détails du suivi"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Télécharger l'instantané vierge",
+ "aria": "Télécharger l'instantané vierge"
}
},
"dialog": {
"confirmDelete": {
"title": "Confirmer la suppression",
- "desc": "La suppression de cet objet suivi supprime l'instantané, les représentations numériques enregistrées et les entrées du cycle de vie de l'objet associé. Les images enregistrées de cet objet suivi dans la vue Historique NE seront PAS supprimées.cameras:front_door label:person before:01012024 time_range:3:00PM-4:00PM ",
"step": "clean_copy soient activés dans votre configuration.",
- "title": "Configuration de l'instantané",
+ "desc": "La soumission à Frigate+ nécessite à la fois que les instantanés et les instantanés clean_copy soient activés dans votre configuration.",
+ "title": "Configuration des instantanés",
"table": {
"snapshots": "Instantanés",
"camera": "Caméra",
- "cleanCopySnapshots": "clean_copy Instantanés"
+ "cleanCopySnapshots": "Instantanés clean_copy"
},
"cleanCopyWarning": "Certaines caméras ont des instantanés activés, mais la copie propre est désactivée. Vous devez activer clean_copy dans votre configuration d'instantanés pour pouvoir envoyer les images de ces caméras à Frigate+."
},
@@ -166,7 +180,7 @@
"supportedDetectors": "Détecteurs pris en charge",
"loading": "Chargement des informations du modèle…",
"title": "Informations sur le modèle",
- "trainDate": "Date d'entrainement",
+ "trainDate": "Date d'entraînement",
"error": "Échec du chargement des informations du modèle",
"availableModels": "Modèles disponibles",
"dimensions": "Dimensions",
@@ -182,7 +196,7 @@
"error": "Échec de l'enregistrement des modifications de configuration : {{errorMessage}}"
},
"restart_required": "Redémarrage requis (modèle Frigate+ changé)",
- "unsavedChanges": "Modifications de paramètres de Frigate+ non enregistrés"
+ "unsavedChanges": "Modifications de paramètres de Frigate+ non enregistrées"
},
"classification": {
"title": "Paramètres de classification",
@@ -278,6 +292,44 @@
"streams": {
"title": "Flux",
"desc": "Désactive temporairement une caméra jusqu'au redémarrage de Frigate. La désactivation complète d'une caméra interrompt le traitement des flux de cette caméra par Frigate. La détection, l'enregistrement et le débogage seront indisponibles.Cadres de mouvement
Des cadres rouges seront superposées sur les zones de l'image où un mouvement est actuellement détecté
" + "tips": "Cadres de mouvement
Des cadres rouges seront superposés sur les zones de l'image où un mouvement est actuellement détecté
" }, "regions": { "title": "Régions", - "desc": "Afficher une boîte de la région d'intérêt envoyée au détecteur d'objet", + "desc": "Afficher un cadre de la région d'intérêt envoyée au détecteur d'objet", "tips": "Cadres de région
Des cadres verts lumineux seront superposés sur les zones d'intérêt de l'image qui sont envoyées au détecteur d'objets.
" }, "objectShapeFilterDrawing": { @@ -523,7 +576,20 @@ "noObjects": "Aucun objet", "title": "Débogage", "detectorDesc": "Frigate utilise vos détecteurs ({{detectors}}) pour détecter les objets dans le flux vidéo de votre caméra.", - "desc": "La vue de débogage affiche en temps réel les objets suivis et leurs statistiques. La liste des objets affiche un résumé différé des objets détectés." + "desc": "La vue de débogage affiche en temps réel les objets suivis et leurs statistiques. La liste des objets affiche un résumé différé des objets détectés.", + "paths": { + "title": "Trajets", + "desc": "Afficher les points notables du trajet de l'objet suivi", + "tips": "Trajets
Les lignes et les cercles indiqueront les points notables où l'objet suivi s'est déplacé pendant son cycle de vie.
" + }, + "audio": { + "title": "Audio", + "noAudioDetections": "Aucune détection audio", + "score": "score", + "currentRMS": "RMS actuel", + "currentdbFS": "dbFS actuel" + }, + "openCameraWebUI": "Ouvrir l'interface Web de {{camera}}" }, "users": { "title": "Utilisateurs", @@ -532,7 +598,7 @@ "desc": "Gérez les comptes utilisateurs de cette instance Frigate." }, "addUser": "Ajouter un utilisateur", - "updatePassword": "Mettre à jour le mot de passe", + "updatePassword": "Réinitialiser le mot de passe", "toast": { "success": { "roleUpdated": "Rôle mis à jour pour {{user}}", @@ -552,7 +618,7 @@ "actions": "Actions", "noUsers": "Aucun utilisateur trouvé.", "changeRole": "Changer le rôle d'utilisateur", - "password": "Mot de passe", + "password": "Réinitialiser le mot de passe", "deleteUser": "Supprimer un utilisateur", "role": "Rôle" }, @@ -560,35 +626,48 @@ "form": { "user": { "title": "Nom d'utilisateur", - "placeholder": "Entrez le nom d'utilisateur", + "placeholder": "Saisir le nom d'utilisateur", "desc": "Seules les lettres, les chiffres, les points et les traits de soulignement sont autorisés." }, "password": { "strength": { "weak": "Faible", - "title": "Sécurité du mot de passe : ", + "title": "Niveau de sécurité du mot de passe : ", "medium": "Moyen", "strong": "Fort", "veryStrong": "Très fort" }, "match": "Les mots de passe correspondent", - "notMatch": "Les mots de passe ne correspondent pas", - "placeholder": "Entrez le mot de passe", + "notMatch": "Les mots de passe ne correspondent pas.", + "placeholder": "Saisir le mot de passe", "title": "Mot de passe", "confirm": { - "title": "Confirmez le mot de passe", - "placeholder": "Confirmez le mot de passe" + "title": "Confirmer le mot de passe", + "placeholder": "Confirmer le mot de passe" + }, + "show": "Afficher le mot de passe", + "hide": "Masquer le mot de passe", + "requirements": { + "title": "Critères du mot de passe :", + "length": "Au moins 12 caractères", + "uppercase": "Au moins une lettre majuscule", + "digit": "Au moins un chiffre", + "special": "Au moins un caractère spécial (!@#$%^&*(),.?\":{}|<>)" } }, "newPassword": { "title": "Nouveau mot de passe", - "placeholder": "Entrez le nouveau mot de passe", + "placeholder": "Saisissez le nouveau mot de passe.", "confirm": { - "placeholder": "Ré-entrez le nouveau mot de passe" + "placeholder": "Confirmez le nouveau mot de passe." } }, - "usernameIsRequired": "Le nom d'utilisateur est requis", - "passwordIsRequired": "Mot de passe requis" + "usernameIsRequired": "Nom d'utilisateur requis", + "passwordIsRequired": "Mot de passe requis", + "currentPassword": { + "title": "Mot de passe actuel", + "placeholder": "Saisissez votre mot de passe actuel" + } }, "deleteUser": { "title": "Supprimer un utilisateur", @@ -597,10 +676,15 @@ }, "passwordSetting": { "updatePassword": "Mettre à jour le mot de passe pour {{username}}", - "setPassword": "Définir le mot de passe", + "setPassword": "Configurer un mot de passe", "desc": "Créez un mot de passe fort pour sécuriser ce compte.", "doNotMatch": "Les mots de passe ne correspondent pas", - "cannotBeEmpty": "Le mot de passe ne peut être vide" + "cannotBeEmpty": "Le mot de passe ne peut être vide", + "currentPasswordRequired": "Le mot de passe actuel est requis.", + "incorrectCurrentPassword": "Le mot de passe actuel est incorrect", + "passwordVerificationFailed": "Échec de la vérification du mot de passe", + "multiDeviceWarning": "Tout autre appareil connecté devra se reconnecter dans un délai de {{refresh_time}}.", + "multiDeviceAdmin": "Vous pouvez également forcer la ré-authentification immédiate de tous les utilisateurs en renouvelant votre clé de sécurité JWT." }, "changeRole": { "title": "Changer le rôle de l'utilisateur", @@ -610,42 +694,43 @@ "admin": "Administrateur", "adminDesc": "Accès complet à l'ensemble des fonctionnalités.", "viewer": "Observateur", - "viewerDesc": "Limité aux tableaux de bord Direct, Revue d'événements, Explorer et Exports." + "viewerDesc": "Limité aux tableaux de bord Direct, Activités, Explorer et Exports.", + "customDesc": "Rôle personnalisé avec accès spécifique à la caméra" }, "select": "Sélectionnez un rôle" }, "createUser": { "title": "Créer un nouvel utilisateur", "desc": "Ajoutez un nouveau compte utilisateur et spécifiez un rôle pour accéder aux zones de l'interface utilisateur Frigate.", - "usernameOnlyInclude": "Le nom d'utilisateur ne peut inclure que des lettres, des chiffres, . ou _", + "usernameOnlyInclude": "Le nom d'utilisateur ne peut inclure que des lettres, des chiffres, des points (.) ou des traits de soulignement (_).", "confirmPassword": "Veuillez confirmer votre mot de passe" } } }, "enrichments": { - "title": "Paramètres des données augmentées", + "title": "Paramètres d'enrichissements", "birdClassification": { "title": "Identification des oiseaux", - "desc": "L'identification des oiseaux est réalisée à l'aide d'un modèle TensorFlow quantifié. Lorsqu'un oiseau est reconnu, son nom commun est automatiquement ajouté comme sous-libellé. Cette information est intégréesà l'interface utilisateur, aux filtres de recherche et aux notifications." + "desc": "L'identification des oiseaux est réalisée à l'aide d'un modèle TensorFlow quantifié. Lorsqu'un oiseau est reconnu, son nom commun est automatiquement ajouté comme sous-étiquette. Cette information est intégrée à l'interface utilisateur, aux filtres de recherche et aux notifications." }, "semanticSearch": { "title": "Recherche sémantique", "readTheDocumentation": "Lire la documentation", "reindexNow": { "label": "Réindexer maintenant", - "desc": "La réindexation va régénérer les représentations numériques pour tous les objets suivis. Ce processus s'exécute en arrière-plan et peut saturer votre processeur et prendre un temps considérable, en fonction du nombre d'objets suivis.", - "confirmTitle": "Confirmez la réindexation", + "desc": "La réindexation va régénérer les embeddings pour tous les objets suivis. Ce processus s'exécute en arrière-plan et peut saturer votre processeur et prendre un temps considérable en fonction du nombre d'objets suivis.", + "confirmTitle": "Confirmer la réindexation", "confirmButton": "Réindexer", "success": "La réindexation a démarré avec succès.", "alreadyInProgress": "La réindexation est déjà en cours.", "error": "Échec du démarrage de la réindexation : {{errorMessage}}", - "confirmDesc": "Êtes-vous sûr de vouloir réindexer tous les représentations numériques des objets suivis ? Ce processus s'exécutera en arrière-plan, mais il pourrait saturer votre processeur et prendre un temps considérable. Vous pouvez suivre la progression sur la page Explorer." + "confirmDesc": "Êtes-vous sûr de vouloir réindexer tous les embeddings des objets suivis ? Ce processus s'exécutera en arrière-plan, mais il pourrait saturer votre processeur et prendre un temps considérable. Vous pouvez suivre la progression sur la page Explorer." }, "modelSize": { - "desc": "La taille du modèle utilisé pour les représentations numériques de recherche sémantique.", + "desc": "La taille du modèle utilisé pour les embeddings de recherche sémantique", "small": { "title": "petit", - "desc": "Utiliser petit emploie une version quantifiée du modèle qui utilise moins de mémoire et s'exécute plus rapidement sur le processeur avec une différence négligeable dans la qualité des représentations numériques." + "desc": "Utiliser petit emploie une version quantifiée du modèle qui utilise moins de mémoire et s'exécute plus rapidement sur le processeur avec une différence négligeable dans la qualité des embeddings." }, "large": { "title": "grand", @@ -653,35 +738,577 @@ }, "label": "Taille du modèle" }, - "desc": "La recherche sémantique de Frigate vous permet de retrouver les objets suivis dans votre revue d'évènements en utilisant soit l'image elle-même, soit une description textuelle définie par l'utilisateur, soit une description générée automatiquement." + "desc": "La recherche sémantique de Frigate permet de retrouver des objets suivis au sein de vos activités en utilisant l'image elle-même, une description personnalisée ou une description générée automatiquement." }, - "unsavedChanges": "Modifications non enregistrées des paramètres des données augmentées", + "unsavedChanges": "Modifications non enregistrées des paramètres d'enrichissements", "faceRecognition": { "title": "Reconnaissance faciale", "readTheDocumentation": "Lire la documentation", "modelSize": { "label": "Taille du modèle", - "desc": "La taille du modèle utilisé pour la reconnaissance faciale.", + "desc": "La taille du modèle utilisé pour la reconnaissance faciale", "small": { "title": "petit", - "desc": "Utiliser petit emploie un modèle de représentation numérique faciale FaceNet qui s'exécute efficacement sur la plupart des processeurs." + "desc": "Utiliser petit emploie un modèle d'embedding facial FaceNet qui s'exécute efficacement sur la plupart des processeurs." }, "large": { "title": "grand", - "desc": "Utiliser grand emploie un modèle de représentation numérique faciale ArcFace et s'exécutera automatiquement sur le GPU si disponible." + "desc": "Utiliser grand emploie un modèle d'embedding facial ArcFace et s'exécutera automatiquement sur le GPU si disponible." } }, - "desc": "La reconnaissance faciale permet à Frigate d'identifier les individus par leur nom. Dès qu'un visage est reconnu, Frigate associe ce nom comme sous-libellé à l'événement. Ces informations sont ensuite intégrées dans l'interface utilisateur, les options de filtrage et les notifications." + "desc": "La reconnaissance faciale permet à Frigate d'identifier les individus par leur nom. Dès qu'un visage est reconnu, Frigate associe ce nom comme sous-étiquette à l'événement. Ces informations sont ensuite intégrées dans l'interface utilisateur, les options de filtrage et les notifications." }, "licensePlateRecognition": { "title": "Reconnaissance des plaques d'immatriculation", "readTheDocumentation": "Lire la documentation", - "desc": "Frigate identifie les plaques d'immatriculation des véhicules et peut automatiquement insérer les caractères détectés dans le champ recognized_license_plate. Il est également capable d'assigner un nom familier comme sous-libellé aux objets de type \"voiture\". Par exemple, cette fonction est souvent utilisée pour lire les plaques des véhicules empruntant une allée ou une rue." + "desc": "Frigate identifie les plaques d'immatriculation des véhicules et peut automatiquement insérer les caractères détectés dans le champ recognized_license_plate. Il est également capable d'assigner un nom familier comme sous-étiquette aux objets de type \"voiture\". Par exemple, cette fonction est souvent utilisée pour lire les plaques des véhicules empruntant une allée ou une rue." }, "toast": { "error": "Échec de l'enregistrement des modifications de configuration : {{errorMessage}}", - "success": "Les paramètres de données augmentées ont été enregistrés. Redémarrez Frigate pour appliquer les modifications." + "success": "Les paramètres d'enrichissements ont été enregistrés. Redémarrez Frigate pour appliquer vos modifications." }, - "restart_required": "Redémarrage nécessaire (paramètres des données augmentées modifiés)" + "restart_required": "Redémarrage nécessaire (paramètres d'enrichissements modifiés)" + }, + "triggers": { + "documentTitle": "Déclencheurs", + "management": { + "title": "Déclencheurs", + "desc": "Gérer les déclencheurs pour {{camera}}. Utilisez le type vignette pour déclencher à partir de vignettes similaires à l'objet suivi sélectionné. Utilisez le type description pour déclencher à partir de textes de description similaires que vous avez spécifiés." + }, + "addTrigger": "Ajouter un déclencheur", + "table": { + "name": "Nom", + "type": "Type", + "content": "Contenu", + "threshold": "Seuil", + "actions": "Actions", + "noTriggers": "Aucun déclencheur configuré pour cette caméra.", + "edit": "Modifier", + "deleteTrigger": "Supprimer le déclencheur", + "lastTriggered": "Dernier déclencheur" + }, + "type": { + "thumbnail": "Vignette", + "description": "Description" + }, + "actions": { + "alert": "Marquer comme alerte", + "notification": "Envoyer une notification", + "sub_label": "Ajouter une sous-étiquette", + "attribute": "Ajouter un attribut" + }, + "dialog": { + "createTrigger": { + "title": "Créer un déclencheur", + "desc": "Créer un déclencheur pour la caméra {{camera}}" + }, + "editTrigger": { + "title": "Modifier le déclencheur", + "desc": "Modifier les paramètres du déclencheur de la caméra {{camera}}" + }, + "deleteTrigger": { + "title": "Supprimer le déclencheur", + "desc": "Êtes-vous sûr de vouloir supprimer le déclencheur {{triggerName}} ? Cette action est irréversible." + }, + "form": { + "name": { + "title": "Nom", + "placeholder": "Nommez ce déclencheur", + "error": { + "minLength": "Le champ doit comporter au moins deux caractères.", + "invalidCharacters": "Le champ peut contenir uniquement des lettres, des nombres, des tirets bas, et des tirets.", + "alreadyExists": "Un déclencheur avec le même nom existe déjà pour cette caméra." + }, + "description": "Saisissez un nom ou une description unique pour identifier ce déclencheur." + }, + "enabled": { + "description": "Activer ou désactiver ce déclencheur" + }, + "type": { + "title": "Type", + "placeholder": "Sélectionner un type de déclencheur", + "description": "Déclencher lorsqu'une description d'objet suivi similaire est détectée", + "thumbnail": "Déclencher lorsqu'une vignette d'objet suivi similaire est détectée" + }, + "content": { + "title": "Contenu", + "imagePlaceholder": "Sélectionner une vignette", + "textPlaceholder": "Saisir le contenu du texte", + "imageDesc": "Seules les 100 vignettes les plus récentes sont affichées. Si vous ne trouvez pas la vignette souhaitée, veuillez consulter les objets précédents dans Explorer et configurer un déclencheur à partir de ce menu.", + "textDesc": "Entrez un texte pour déclencher cette action lorsqu'une description similaire d'objet suivi est détectée.", + "error": { + "required": "Le contenu est requis." + } + }, + "threshold": { + "title": "Seuil", + "error": { + "min": "Le seuil doit être au moins 0", + "max": "Le seuil peut être au plus 1" + }, + "desc": "Définissez le seuil de similarité pour ce déclencheur. Un seuil plus élevé signifie qu'une correspondance plus exacte est requise pour activer le déclencheur." + }, + "actions": { + "title": "Actions", + "desc": "Par défaut, Frigate envoie un message MQTT pour tous les déclencheurs. Les sous-étiquettes ajoutent le nom du déclencheur à l'étiquette de l'objet. Les attributs sont des métadonnées recherchables stockées séparément dans les métadonnées de l'objet suivi.", + "error": { + "min": "Au moins une action doit être sélectionnée." + } + }, + "friendly_name": { + "title": "Nom convivial", + "placeholder": "Nommez ou décrivez ce déclencheur", + "description": "Nom convivial ou texte descriptif facultatif pour ce déclencheur." + } + } + }, + "toast": { + "success": { + "createTrigger": "Le déclencheur {{name}} a été créé avec succès.", + "updateTrigger": "Le déclencheur {{name}} a été mis à jour avec succès.", + "deleteTrigger": "Le déclencheur {{name}} a été supprimé avec succès." + }, + "error": { + "createTriggerFailed": "Échec de la création du déclencheur : {{errorMessage}}", + "updateTriggerFailed": "Échec de la mise à jour du déclencheur : {{errorMessage}}", + "deleteTriggerFailed": "Échec de la suppression du déclencheur : {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "La recherche sémantique est désactivée", + "desc": "La recherche sémantique doit être activée pour utiliser les déclencheurs." + }, + "wizard": { + "title": "Créer un déclencheur", + "step1": { + "description": "Configurez les paramètres de base pour votre déclencheur." + }, + "step2": { + "description": "Configurez le contenu qui déclenchera cette action." + }, + "step3": { + "description": "Configurez le seuil et les actions pour ce déclencheur." + }, + "steps": { + "nameAndType": "Nom et type", + "configureData": "Configuration des données", + "thresholdAndActions": "Seuil et actions" + } + } + }, + "roles": { + "management": { + "title": "Gestion des rôles Observateur", + "desc": "Gérer les rôles Observateur personnalisés et leurs permissions d'accès aux caméras pour cette instance de Frigate." + }, + "addRole": "Ajouter un rôle", + "table": { + "role": "Rôle", + "cameras": "Caméras", + "actions": "Actions", + "noRoles": "Aucun rôle personnalisé trouvé.", + "editCameras": "Modifier les caméras", + "deleteRole": "Supprimer le rôle" + }, + "toast": { + "success": { + "createRole": "Rôle {{role}} créé avec succès", + "updateCameras": "Caméras mis à jour pour le rôle {{role}}", + "deleteRole": "Rôle {{role}} supprimé avec succès", + "userRolesUpdated_one": "{{count}} utilisateur affecté à ce rôle a été mis à jour avec des droits \"Observateur\", et a accès à toutes les caméras.", + "userRolesUpdated_many": "{{count}} utilisateurs affectés à ce rôle ont été mis à jour avec des droits \"Observateur\", et ont accès à toutes les caméras.", + "userRolesUpdated_other": "{{count}} utilisateurs affectés à ce rôle ont été mis à jour avec des droits \"Observateur\", et ont accès à toutes les caméras." + }, + "error": { + "createRoleFailed": "Échec dans la création du rôle : {{errorMessage}}", + "updateCamerasFailed": "Échec de la mise à jour des caméras : {{errorMessage}}", + "deleteRoleFailed": "Échec lors de la suppression du rôle : {{errorMessage}}", + "userUpdateFailed": "Echec lors de la mise à jour des rôles de l'utilisateur : {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Créer un nouveau rôle", + "desc": "Ajouter un nouveau rôle et définir les permissions d'accès à la caméra." + }, + "editCameras": { + "title": "Modifier les caméras du rôle", + "desc": "Mettre à jour les accès aux caméras pour le rôle {{role}}." + }, + "deleteRole": { + "title": "Suppression du rôle", + "desc": "Cette action est irréversible. Elle supprimera définitivement le rôle et tous les utilisateurs associés seront affectés au rôle \"Observateur\", avec un accès à toutes les caméras.", + "warn": "Êtes-vous sûr de vouloir supprimer {{role}} ?", + "deleting": "En cours de suppression..." + }, + "form": { + "role": { + "title": "Nom du rôle", + "placeholder": "Saisissez un nom de rôle.", + "desc": "Seuls les lettres, les chiffres, les points et les traits de soulignement sont autorisés.", + "roleIsRequired": "Un nom de rôle est requis", + "roleOnlyInclude": "Le nom de rôle ne peut inclure que des lettres, des chiffres, des points (.) ou des traits de soulignement (_).", + "roleExists": "Un rôle avec ce nom existe déjà." + }, + "cameras": { + "title": "Caméras", + "desc": "Sélectionnez les caméras auxquelles ce rôle aura accès. Au moins une caméra est requise.", + "required": "Au moins une caméra doit être sélectionnée." + } + } + } + }, + "cameraWizard": { + "title": "Ajouter une caméra", + "description": "Suivez les étapes ci-dessous pour ajouter une nouvelle caméra à votre installation Frigate.", + "steps": { + "nameAndConnection": "Nom et connexion", + "streamConfiguration": "Configuration du flux", + "validationAndTesting": "Validation et tests", + "probeOrSnapshot": "Sondage ou Instantané" + }, + "save": { + "success": "Nouvelle caméra {{cameraName}} enregistrée avec succès", + "failure": "Échec lors de l'enregistrement de {{cameraName}}" + }, + "testResultLabels": { + "resolution": "Résolution", + "video": "Vidéo", + "audio": "Audio", + "fps": "FPS" + }, + "commonErrors": { + "noUrl": "Veuillez saisir une URL de flux valide.", + "testFailed": "Échec du test de flux : {{error}}" + }, + "step1": { + "description": "Saisissez les détails de votre caméra et choisissez d'interroger la caméra ou de sélectionner manuellement la marque.", + "cameraName": "Nom de la caméra", + "cameraNamePlaceholder": "par ex., porte_entree ou apercu_cour_arriere", + "host": "Hôte / Adresse IP", + "port": "Port", + "username": "Nom d'utilisateur", + "usernamePlaceholder": "Facultatif", + "password": "Mot de passe", + "passwordPlaceholder": "Facultatif", + "selectTransport": "Sélectionnez le protocole de transport.", + "cameraBrand": "Marque de la caméra", + "selectBrand": "Sélectionnez la marque de la caméra pour déterminer la forme de l'URL.", + "customUrl": "URL de flux personnalisé", + "brandInformation": "Information sur la marque", + "brandUrlFormat": "Pour les caméras avec un format d'URL RTSP comme : {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://nomutilisateur:motdepasse@hote:port/chemin", + "testConnection": "Tester la connexion", + "testSuccess": "Test de connexion réussi !", + "testFailed": "Échec du test de connexion. Veuillez vérifier votre saisie et réessayez.", + "streamDetails": "Détails du flux", + "warnings": { + "noSnapshot": "Impossible de récupérer un instantané à partir du flux configuré" + }, + "errors": { + "brandOrCustomUrlRequired": "Sélectionnez une marque de caméra avec hôte/IP ou choisissez « Autre » avec une URL personnalisée.", + "nameRequired": "Le nom de la caméra est requis.", + "nameLength": "Le nom de la caméra ne doit pas dépasser 64 caractères.", + "invalidCharacters": "Le nom de la caméra contient des caractères invalides.", + "nameExists": "Ce nom de caméra est déjà utilisé.", + "brands": { + "reolink-rtsp": "Le protocole RTSP de Reolink est déconseillé. Activez le protocole HTTP dans les paramètres du firmware de la caméra, puis relancez l'assistant." + }, + "customUrlRtspRequired": "Les URL personnalisées doivent commencer par \"rtsp://\". Une configuration manuelle est requise pour les flux de caméra non-RTSP." + }, + "docs": { + "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras" + }, + "testing": { + "probingMetadata": "Vérification des métadonnées de la caméra en cours...", + "fetchingSnapshot": "Récupération de l'instantané de la caméra en cours..." + }, + "connectionSettings": "Paramètres de connexion", + "detectionMethod": "Méthode de détection du flux", + "onvifPort": "Port ONVIF", + "probeMode": "Interroger la caméra", + "manualMode": "Sélection manuelle", + "detectionMethodDescription": "Interrogez la caméra avec ONVIF (si pris en charge) pour trouver les URL de flux de la caméra, ou sélectionnez manuellement la marque de la caméra pour utiliser des URL prédéfinies. Pour saisir une URL RTSP personnalisée, choisissez la méthode manuelle et sélectionnez \"Autre\".", + "onvifPortDescription": "Pour les caméras prenant en charge ONVIF, il s'agit généralement de 80 ou 8080.", + "useDigestAuth": "Utiliser l'authentification Digest", + "useDigestAuthDescription": "Utilisez l'authentification Digest HTTP pour ONVIF. Certaines caméras peuvent nécessiter un nom d'utilisateur/mot de passe ONVIF dédié au lieu de l'utilisateur administrateur standard." + }, + "step2": { + "description": "Interrogez la caméra pour les flux disponibles ou configurez des paramètres manuels en fonction de la méthode de détection sélectionnée.", + "streamsTitle": "Flux de caméra", + "addStream": "Ajouter un flux", + "addAnotherStream": "Ajouter un autre flux", + "streamTitle": "Flux {{number}}", + "streamUrl": "URL du flux", + "streamUrlPlaceholder": "rtsp://nomutilisateur:motdepasse@hote:port/chemin", + "url": "URL", + "resolution": "Résolution", + "selectResolution": "Sélectionnez la résolution.", + "quality": "Qualité", + "selectQuality": "Sélectionnez la qualité.", + "roles": "Rôles", + "roleLabels": { + "record": "Enregistrement", + "audio": "Audio", + "detect": "Détection d'objets" + }, + "testStream": "Tester la connexion", + "testSuccess": "Test de connexion réussi !", + "testFailed": "Échec du test de connexion. Veuillez vérifier votre saisie et réessayer.", + "testFailedTitle": "Échec du test", + "connected": "Connecté", + "notConnected": "Non connecté", + "featuresTitle": "Caractéristiques", + "go2rtc": "Réduire le nombre de connexions à la caméra", + "detectRoleWarning": "Pour continuer, au moins un flux doit avoir le rôle \"détection\".", + "rolesPopover": { + "title": "Rôles du flux", + "detect": "Flux principal pour la détection d'objets", + "record": "Enregistre des extraits du flux vidéo en fonction des paramètres de configuration.", + "audio": "Flux pour la détection audio" + }, + "featuresPopover": { + "title": "Fonctionnalités du flux", + "description": "Utilisez la rediffusion du flux go2rtc pour réduire le nombre de connexions à votre caméra." + }, + "streamDetails": "Détails du flux", + "probing": "Interrogation de la caméra en cours...", + "retry": "Réessayer", + "testing": { + "probingMetadata": "Interrogation des métadonnées de la caméra en cours...", + "fetchingSnapshot": "Récupération de l'instantané de la caméra en cours..." + }, + "probeFailed": "Impossible d'interroger la caméra : {{error}}", + "probingDevice": "Interrogation de l'appareil en cours...", + "probeSuccessful": "Interrogation réussie", + "probeError": "Erreur d'interrogation", + "probeNoSuccess": "Échec de l'interrogation", + "deviceInfo": "Informations sur l'appareil", + "manufacturer": "Fabricant", + "model": "Modèle", + "firmware": "Micrologiciel", + "profiles": "Profils", + "ptzSupport": "Prise en charge PTZ", + "autotrackingSupport": "Prise en charge du suivi automatique", + "presets": "Préréglages", + "rtspCandidates": "Candidats RTSP", + "rtspCandidatesDescription": "Les URL RTSP suivantes ont été trouvées lors de l'interrogation de la caméra. Testez la connexion pour afficher les métadonnées du flux.", + "noRtspCandidates": "Aucune URL RTSP n'a été trouvée sur la caméra. Vos identifiants sont peut-être incorrects, ou la caméra ne prend peut-être pas en charge ONVIF ou la méthode utilisée pour récupérer les URL RTSP. Revenez en arrière et saisissez l'URL RTSP manuellement.", + "candidateStreamTitle": "Candidat {{number}}", + "useCandidate": "Utiliser", + "uriCopy": "Copier", + "uriCopied": "URI copiée dans le presse-papiers", + "testConnection": "Tester la connexion", + "toggleUriView": "Cliquer pour basculer l'affichage de l'URI complet", + "errors": { + "hostRequired": "L'hôte/adresse IP est requis." + } + }, + "step3": { + "description": "Configurez les rôles des flux et ajoutez des flux supplémentaires pour votre caméra.", + "validationTitle": "Validation du flux", + "connectAllStreams": "Connecter tous les flux", + "reconnectionSuccess": "Reconnexion réussie.", + "reconnectionPartial": "La reconnexion de certains flux a échoué.", + "streamUnavailable": "Aperçu du flux indisponible", + "reload": "Recharger", + "connecting": "Connexion en cours...", + "streamTitle": "Flux {{number}}", + "failed": "Échec", + "notTested": "Non testé", + "connectStream": "Connecter", + "connectingStream": "Connexion en cours", + "disconnectStream": "Déconnecter", + "estimatedBandwidth": "Débit estimé", + "roles": "Rôles", + "none": "Aucun", + "error": "Erreur", + "streamValidated": "Flux {{number}} validé avec succès", + "streamValidationFailed": "La validation du flux {{number}} a échoué", + "saveAndApply": "Enregistrer une nouvelle caméra", + "saveError": "Configuration invalide. Veuillez vérifier vos paramètres.", + "issues": { + "title": "Validation du flux", + "videoCodecGood": "Le codec vidéo est {{codec}}.", + "audioCodecGood": "Le codec audio est {{codec}}.", + "noAudioWarning": "Aucun son n'est détecté sur ce flux, les enregistrements seront muets.", + "audioCodecRecordError": "Le codec audio AAC est requis pour la prise en charge du son dans les enregistrements.", + "audioCodecRequired": "Un flux audio est requis pour prendre en charge la détection audio.", + "restreamingWarning": "La réduction des connexions à la caméra pour le flux d'enregistrement peut augmenter légèrement l'utilisation du processeur.", + "dahua": { + "substreamWarning": "Le flux secondaire 1 est limité en basse résolution. De nombreuses caméras (Dahua, Amcrest, EmpireTech...) proposent des flux supplémentaires qu'il suffit d'activer dans leurs propres paramètres. Il est recommandé de vérifier leur disponibilité et de les utiliser." + }, + "hikvision": { + "substreamWarning": "Le flux secondaire 1 est limité en basse résolution. De nombreuses caméras Hikvision proposent des flux supplémentaires qu'il suffit d'activer dans leurs propres paramètres. Il est recommandé de vérifier leur disponibilité et de les utiliser." + }, + "resolutionHigh": "La résolution {{resolution}} risque d'augmenter l'utilisation des ressources.", + "resolutionLow": "La résolution {{resolution}} risque d'être trop faible pour détecter les petits objets de manière fiable." + }, + "valid": "Valide", + "ffmpegModule": "Utiliser le mode de compatibilité du flux", + "ffmpegModuleDescription": "Si le flux ne se charge pas après plusieurs tentatives, essayez d'activer cette option. Lorsqu'elle est activée, Frigate utilisera le module ffmpeg avec go2rtc. Cela peut offrir une meilleure compatibilité avec certains flux de caméra.", + "streamsTitle": "Flux de la caméra", + "addStream": "Ajouter un flux", + "addAnotherStream": "Ajouter un autre flux", + "streamUrl": "URL du flux", + "streamUrlPlaceholder": "rtsp://nomdutilisateur:motdepasse@hote:port/chemin", + "selectStream": "Sélectionner un flux", + "searchCandidates": "Rechercher des candidats", + "noStreamFound": "Aucun flux trouvé", + "url": "URL", + "resolution": "Résolution", + "selectResolution": "Sélectionner la résolution", + "quality": "Qualité", + "selectQuality": "Sélectionner la qualité", + "roleLabels": { + "detect": "Détection d'objet", + "record": "Enregistrement", + "audio": "Audio" + }, + "testStream": "Tester la connexion", + "testSuccess": "Test du flux réussi !", + "testFailed": "Échec du test du flux", + "testFailedTitle": "Échec du test", + "connected": "Connecté", + "notConnected": "Non connecté", + "featuresTitle": "Fonctionnalités", + "go2rtc": "Réduire les connexions à la caméra", + "detectRoleWarning": "Au moins un flux doit avoir le rôle 'détection' pour continuer.", + "rolesPopover": { + "title": "Rôles du flux", + "detect": "Flux principal pour la détection d'objet", + "record": "Enregistre des segments du flux vidéo en fonction des paramètres de configuration", + "audio": "Flux pour la détection basée sur l'audio" + }, + "featuresPopover": { + "title": "Fonctionnalités du flux", + "description": "Utiliser la rediffusion go2rtc pour réduire les connexions à votre caméra" + } + }, + "step4": { + "description": "Validation et analyse finales avant d'enregistrer votre nouvelle caméra. Connectez chaque flux avant d'enregistrer.", + "validationTitle": "Validation du flux", + "connectAllStreams": "Connecter tous les flux", + "reconnectionSuccess": "Reconnexion réussie", + "reconnectionPartial": "Certains flux n'ont pas réussi à se reconnecter.", + "streamUnavailable": "Aperçu du flux non disponible", + "reload": "Recharger", + "connecting": "En cours de connexion...", + "streamTitle": "Flux {{number}}", + "valid": "Valide", + "failed": "Échec", + "notTested": "Non testé", + "connectStream": "Connecter", + "connectingStream": "En cours de connexion", + "disconnectStream": "Déconnecter", + "estimatedBandwidth": "Bande passante estimée", + "roles": "Rôles", + "ffmpegModule": "Utiliser le mode de compatibilité du flux", + "ffmpegModuleDescription": "Si le flux ne se charge pas après plusieurs tentatives, essayez d'activer cette option. Lorsqu'elle est activée, Frigate utilisera le module ffmpeg avec go2rtc. Cela peut offrir une meilleure compatibilité avec certains flux de caméra.", + "none": "Aucun", + "error": "Erreur", + "streamValidated": "Flux {{number}} validé avec succès", + "streamValidationFailed": "Échec de la validation du flux {{number}}", + "saveAndApply": "Enregistrer la nouvelle caméra", + "saveError": "Configuration invalide. Veuillez vérifier vos paramètres.", + "issues": { + "title": "Validation du flux", + "videoCodecGood": "Le codec vidéo est {{codec}}.", + "audioCodecGood": "Le codec audio est {{codec}}.", + "resolutionHigh": "Une résolution de {{resolution}} peut entraîner une utilisation accrue des ressources.", + "resolutionLow": "Une résolution de {{resolution}} peut être trop faible pour une détection fiable des petits objets.", + "noAudioWarning": "Aucun audio détecté pour ce flux, les enregistrements n'auront pas de son.", + "audioCodecRecordError": "Le codec audio AAC est requis pour prendre en charge l'audio dans les enregistrements.", + "audioCodecRequired": "Un flux audio est requis pour prendre en charge la détection audio.", + "restreamingWarning": "Réduire les connexions à la caméra pour le flux d'enregistrement peut légèrement augmenter l'utilisation du processeur.", + "brands": { + "reolink-rtsp": "Le RTSP Reolink n'est pas recommandé. Activez HTTP dans les paramètres du micrologiciel de la caméra et redémarrez l'assistant.", + "reolink-http": "Les flux HTTP de Reolink devraient utiliser FFmpeg pour une meilleure compatibilité. Activez 'Utiliser le mode de compatibilité du flux' pour ce flux." + }, + "dahua": { + "substreamWarning": "Le sous-flux 1 est limité à une basse résolution. De nombreuses caméras Dahua / Amcrest / EmpireTech prennent en charge des sous-flux supplémentaires qui doivent être activés dans les paramètres de la caméra. Il est recommandé de vérifier et d'utiliser ces flux s'ils sont disponibles." + }, + "hikvision": { + "substreamWarning": "Le sous-flux 1 est limité à une basse résolution. De nombreuses caméras Hikvision prennent en charge des sous-flux supplémentaires qui doivent être activés dans les paramètres de la caméra. Il est recommandé de vérifier et d'utiliser ces flux s'ils sont disponibles." + } + } + } + }, + "cameraManagement": { + "title": "Gérer les caméras", + "addCamera": "Ajouter une nouvelle caméra", + "editCamera": "Modifier la caméra :", + "selectCamera": "Sélectionnez une caméra", + "backToSettings": "Retour aux paramètres de la caméra", + "streams": { + "title": "Activer / désactiver les caméras", + "desc": "Désactive temporairement une caméra jusqu'au redémarrage de Frigate. La désactivation d'une caméra interrompt complètement le traitement des flux de la caméra par Frigate. La détection, l'enregistrement et le débogage deviennent alors indisponibles.ffprobe.",
+ "streamDataFromFFPROBE": "Les données du flux sont obtenues avec ffprobe.",
"resolution": "Résolution :",
"error": "Erreur : {{error}}",
"codec": "Codec :",
"video": "Vidéo :",
- "aspectRatio": "ratio d'aspect"
+ "aspectRatio": "rapport d'aspect"
},
"framesAndDetections": "Images / Détections",
"label": {
"camera": "caméra",
- "detect": "Détecter",
- "skipped": "ignoré",
+ "detect": "détection",
+ "skipped": "ignorées",
"ffmpeg": "FFmpeg",
"capture": "capture",
"cameraFfmpeg": "{{camName}} FFmpeg",
- "cameraSkippedDetectionsPerSecond": "{{camName}} détections manquées par seconde",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} détections ignorées par seconde",
"overallDetectionsPerSecond": "Moyenne de détections par seconde",
- "overallFramesPerSecond": "Moyenne d'images par seconde",
- "overallSkippedDetectionsPerSecond": "Moyenne de détections manquées par seconde",
+ "overallFramesPerSecond": "images par seconde (global)",
+ "overallSkippedDetectionsPerSecond": "Moyenne de détections ignorées par seconde",
"cameraCapture": "{{camName}} capture",
"cameraDetect": "{{camName}} détection",
"cameraFramesPerSecond": "{{camName}} images par seconde",
@@ -143,38 +160,49 @@
"overview": "Vue d'ensemble",
"toast": {
"success": {
- "copyToClipboard": "Données récupérées copiées dans le presse-papier."
+ "copyToClipboard": "Données de la sonde copiées dans le presse-papiers"
},
"error": {
- "unableToProbeCamera": "Impossible de récupérer des infos depuis la caméra : {{errorMessage}}"
+ "unableToProbeCamera": "Impossible d'interroger la caméra : {{errorMessage}}"
}
}
},
"lastRefreshed": "Dernier rafraichissement : ",
"stats": {
"ffmpegHighCpuUsage": "{{camera}} a un taux élevé d'utilisation processeur par FFmpeg ({{ffmpegAvg}}%)",
- "detectHighCpuUsage": "{{camera}} a un taux élevé d'utilisation processeur ({{detectAvg}}%)",
+ "detectHighCpuUsage": "{{camera}} : charge CPU détection élevée ({{detectAvg}}%)",
"healthy": "Le système est sain",
- "reindexingEmbeddings": "Réindexation des représentations numériques ({{processed}}% complété)",
+ "reindexingEmbeddings": "Réindexation des embeddings ({{processed}} % terminée)",
"cameraIsOffline": "{{camera}} est hors ligne",
"detectIsSlow": "{{detect}} est lent ({{speed}} ms)",
- "detectIsVerySlow": "{{detect}} est très lent ({{speed}} ms)"
+ "detectIsVerySlow": "{{detect}} est très lent ({{speed}} ms)",
+ "shmTooLow": "L'allocation /dev/shm ({{total}} Mo) devrait être augmentée à au moins {{min}} Mo."
},
"enrichments": {
- "title": "Données augmentées",
+ "title": "Enrichissements",
"infPerSecond": "Inférences par seconde",
"embeddings": {
- "face_embedding_speed": "Vitesse de capture des données complémentaires de visage",
- "text_embedding_speed": "Vitesse de capture des données complémentaire de texte",
- "image_embedding_speed": "Vitesse de capture des données complémentaires à l'image",
+ "face_embedding_speed": "Vitesse de vectorisation des visages",
+ "text_embedding_speed": "Vitesse d'embedding de texte",
+ "image_embedding_speed": "Vitesse d'embedding d'image",
"plate_recognition_speed": "Vitesse de reconnaissance des plaques d'immatriculation",
"face_recognition_speed": "Vitesse de reconnaissance faciale",
"plate_recognition": "Reconnaissance de plaques d'immatriculation",
- "image_embedding": "Représentations numériques d'image",
+ "image_embedding": "Embedding d'image",
"yolov9_plate_detection": "Détection de plaques d'immatriculation YOLOv9",
"face_recognition": "Reconnaissance faciale",
- "text_embedding": "Représentation numérique de texte",
- "yolov9_plate_detection_speed": "Vitesse de détection de plaques d'immatriculation YOLOv9"
- }
+ "text_embedding": "Vitesse d'embedding de visage",
+ "yolov9_plate_detection_speed": "Vitesse de détection de plaques d'immatriculation YOLOv9",
+ "review_description": "Description de l'activité",
+ "review_description_speed": "Vitesse de description des activités",
+ "review_description_events_per_second": "Description de l'activité",
+ "object_description": "Description de l'objet",
+ "object_description_speed": "Vitesse de la description d'objet",
+ "object_description_events_per_second": "Description de l'objet",
+ "classification": "Classification {{name}}",
+ "classification_speed": "Vitesse de classification {{name}}",
+ "classification_events_per_second": "Événements de classification par seconde {{name}}"
+ },
+ "averageInf": "Temps d'inférence moyen"
}
}
diff --git a/web/public/locales/gl/common.json b/web/public/locales/gl/common.json
index 1443cce35..61b9ce58f 100644
--- a/web/public/locales/gl/common.json
+++ b/web/public/locales/gl/common.json
@@ -9,5 +9,6 @@
"today": "Hoxe",
"untilRestart": "Ata o reinicio",
"ago": "Fai {{timeAgo}}"
- }
+ },
+ "readTheDocumentation": "Ler a documentación"
}
diff --git a/web/public/locales/gl/components/auth.json b/web/public/locales/gl/components/auth.json
index 2a0bee0d5..8b0857dac 100644
--- a/web/public/locales/gl/components/auth.json
+++ b/web/public/locales/gl/components/auth.json
@@ -5,7 +5,8 @@
"errors": {
"passwordRequired": "Contrasinal obrigatorio",
"unknownError": "Erro descoñecido. Revisa os logs.",
- "usernameRequired": "Usuario/a obrigatorio"
+ "usernameRequired": "Usuario/a obrigatorio",
+ "rateLimit": "Excedido o límite. Téntao de novo despois."
},
"login": "Iniciar sesión"
}
diff --git a/web/public/locales/gl/components/dialog.json b/web/public/locales/gl/components/dialog.json
index c6519972a..d2aff40d1 100644
--- a/web/public/locales/gl/components/dialog.json
+++ b/web/public/locales/gl/components/dialog.json
@@ -15,6 +15,9 @@
"label": "Confirma esta etiqueta para Frigate Plus",
"ask_an": "E isto un obxecto {{label}}?"
}
+ },
+ "submitToPlus": {
+ "label": "Enviar a Frigate+"
}
}
}
diff --git a/web/public/locales/gl/components/filter.json b/web/public/locales/gl/components/filter.json
index 6927e2e51..8ef5f8fd1 100644
--- a/web/public/locales/gl/components/filter.json
+++ b/web/public/locales/gl/components/filter.json
@@ -6,7 +6,8 @@
"all": {
"short": "Etiquetas",
"title": "Todas as Etiquetas"
- }
+ },
+ "count_other": "{{count}} Etiquetas"
},
"zones": {
"all": {
diff --git a/web/public/locales/gl/views/classificationModel.json b/web/public/locales/gl/views/classificationModel.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/gl/views/classificationModel.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/gl/views/events.json b/web/public/locales/gl/views/events.json
index c5c9cb67b..56da9d9e5 100644
--- a/web/public/locales/gl/views/events.json
+++ b/web/public/locales/gl/views/events.json
@@ -6,5 +6,8 @@
"motion": {
"only": "Só movemento",
"label": "Movemento"
+ },
+ "empty": {
+ "alert": "Non hai alertas que revisar"
}
}
diff --git a/web/public/locales/he/audio.json b/web/public/locales/he/audio.json
index f7369853c..711a8d338 100644
--- a/web/public/locales/he/audio.json
+++ b/web/public/locales/he/audio.json
@@ -18,7 +18,7 @@
"humming": "זמזום",
"groan": "אנקה",
"grunt": "לנחור",
- "whistling": "שריקה",
+ "whistling": "לשרוק",
"breathing": "נשימה",
"wheeze": "גניחה",
"snoring": "נחירה",
@@ -69,7 +69,7 @@
"fly": "זבוב",
"buzz": "זמזם.",
"frog": "צפרדע",
- "croak": "קרקור.",
+ "croak": "קִרקוּר",
"snake": "נחש",
"rattle": "טרטור",
"whale_vocalization": "קולות לוויתן",
@@ -81,7 +81,7 @@
"bass_guitar": "גיטרה בס",
"acoustic_guitar": "גיטרה אקוסטית",
"steel_guitar": "גיטרה פלדה",
- "tapping": "הקשה.",
+ "tapping": "להקיש",
"strum": "פריטה",
"banjo": "בנג'ו",
"sitar": "סיטאר",
@@ -94,7 +94,7 @@
"electronic_organ": "אורגן חשמלי",
"hammond_organ": "עוגב המונד",
"synthesizer": "סינתיסייזר",
- "sampler": "דגם",
+ "sampler": "דוגם",
"harpsichord": "צֶ'מבָּלוֹ",
"percussion": "הַקָשָׁה",
"boat": "סירה",
@@ -102,7 +102,7 @@
"motorcycle": "אופנוע",
"bus": "אוטובוס",
"bicycle": "אופניים",
- "train": "למד פנים",
+ "train": "אימון",
"skateboard": "סקייטבורד",
"camera": "מצלמה",
"howl": "יללה",
@@ -189,7 +189,7 @@
"church_bell": "פעמון כנסיה",
"jingle_bell": "ג'ינגל בל",
"bicycle_bell": "פעמון אופניים",
- "chime": "צלצול",
+ "chime": "צִלצוּל",
"wind_chime": "פעמון רוח",
"harmonica": "הרמוניקה",
"accordion": "אקורדיון",
@@ -341,7 +341,7 @@
"microwave_oven": "מיקרוגל",
"water_tap": "ברז מים",
"bathtub": "אמבטיה",
- "dishes": "כלים.",
+ "dishes": "מנות",
"scissors": "מספריים",
"toothbrush": "מברשת שיניים",
"toilet_flush": "הורדת מים לאסלה",
@@ -355,7 +355,7 @@
"computer_keyboard": "מקלדת מחשב",
"writing": "כתיבה",
"telephone_bell_ringing": "צלצול טלפון",
- "ringtone": "צליל חיוג.",
+ "ringtone": "צלצול",
"clock": "שעון",
"telephone_dialing": "טלפון מחייג",
"dial_tone": "צליל חיוג",
@@ -425,5 +425,79 @@
"slam": "טריקה",
"telephone": "טלפון",
"tuning_fork": "מזלג כוונון",
- "raindrop": "טיפות גשם"
+ "raindrop": "טיפות גשם",
+ "smash": "רסק",
+ "boiling": "רותח",
+ "sonar": "סונר",
+ "arrow": "חץ",
+ "whack": "מַהֲלוּמָה",
+ "sine_wave": "גל סינוס",
+ "harmonic": "הרמוניה",
+ "chirp_tone": "צליל ציוץ",
+ "pulse": "דוֹפֶק",
+ "inside": "בְּתוֹך",
+ "outside": "בחוץ",
+ "reverberation": "הִדהוּד",
+ "echo": "הד",
+ "noise": "רעש",
+ "mains_hum": "זמזום ראשי",
+ "distortion": "סַלְפָנוּת",
+ "sidetone": "צליל צדדי",
+ "cacophony": "קָקוֹפוֹניָה",
+ "throbbing": "פְּעִימָה",
+ "vibration": "רֶטֶט",
+ "sodeling": "מיזוג",
+ "change_ringing": "שינוי צלצול",
+ "shofar": "שופר",
+ "liquid": "נוזל",
+ "splash": "התזה",
+ "slosh": "שכשוך",
+ "squish": "מעיכה",
+ "drip": "טפטוף",
+ "pour": "לִשְׁפּוֹך",
+ "trickle": "לְטַפטֵף",
+ "gush": "פֶּרֶץ",
+ "fill": "מילוי",
+ "spray": "ריסוס",
+ "pump": "משאבה",
+ "stir": "בחישה",
+ "whoosh": "מהיר",
+ "thump": "חֲבָטָה",
+ "thunk": "תרועה",
+ "electronic_tuner": "מכוון אלקטרוני",
+ "effects_unit": "יחידת אפקטים",
+ "chorus_effect": "אפקט מקהלה",
+ "basketball_bounce": "קפיצת כדורסל",
+ "bang": "לִדפּוֹק",
+ "slap": "סְטִירָה",
+ "breaking": "שְׁבִירָה",
+ "bouncing": "הַקפָּצָה",
+ "whip": "שׁוֹט",
+ "flap": "מַדָף",
+ "scratch": "לְגַרֵד",
+ "scrape": "סריקה",
+ "rub": "שפשוף",
+ "roll": "גלגול",
+ "crushing": "מעיכה",
+ "crumpling": "קימוט",
+ "tearing": "קריעה",
+ "beep": "ביפ",
+ "ping": "פינג",
+ "ding": "דינג",
+ "clang": "צלצול מתכתי",
+ "squeal": "חריקה",
+ "creak": "חריקה",
+ "rustle": "רשרוש",
+ "whir": "זמזום",
+ "clatter": "רעש נקישות",
+ "chird": "Chird",
+ "sizzle": "צליל חריכה",
+ "clicking": "נקישות",
+ "clickety_clack": "נקישות רצופות",
+ "rumble": "רעם נמוך",
+ "plop": "פלופ",
+ "hum": "המהום",
+ "zing": "זמזום חד",
+ "boing": "בּוֹאִינְג (צליל קפיצי / אלסטי)",
+ "crunch": "חריקה / פיצוח"
}
diff --git a/web/public/locales/he/common.json b/web/public/locales/he/common.json
index e6c1d632f..1059ae300 100644
--- a/web/public/locales/he/common.json
+++ b/web/public/locales/he/common.json
@@ -78,7 +78,10 @@
"12hour": "MMM d, yyyy"
},
"30minutes": "30 דקות",
- "thisMonth": "החודש"
+ "thisMonth": "החודש",
+ "inProgress": "בתהליך",
+ "invalidStartTime": "זמן התחלה לא תקין",
+ "invalidEndTime": "זמן סיום לא תקין"
},
"unit": {
"speed": {
@@ -88,10 +91,24 @@
"length": {
"feet": "רגל",
"meters": "מטרים"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/hour",
+ "mbph": "MB/hour",
+ "gbph": "GB/hour"
}
},
"label": {
- "back": "אחורה"
+ "back": "אחורה",
+ "hide": "הסתר {{item}}",
+ "show": "הצג {{item}}",
+ "ID": "ID",
+ "none": "ללא",
+ "all": "הכל",
+ "other": "אחר"
},
"button": {
"apply": "החל",
@@ -128,7 +145,8 @@
"on": "פעיל",
"download": "הורדה",
"info": "מידע",
- "next": "הבא"
+ "next": "הבא",
+ "continue": "המשך"
},
"menu": {
"system": "מערכת",
@@ -172,9 +190,17 @@
"ja": "יפנית",
"de": "גרמנית",
"yue": "קנטונזית",
- "ca": "קטלה (קטלאנית)"
+ "ca": "קטלה (קטלאנית)",
+ "ptBR": "פורטוגזית - ברזיל",
+ "sr": "סרבית",
+ "sl": "סלובנית",
+ "lt": "ליטאית",
+ "bg": "בולגרית",
+ "gl": "Galego",
+ "id": "אינדונזית",
+ "ur": "اردو"
},
- "appearance": "מראה.",
+ "appearance": "מראה",
"darkMode": {
"label": "מצב כהה",
"light": "בהיר",
@@ -221,7 +247,8 @@
"current": "משתמש מחובר: {{user}}",
"setPassword": "קביעת סיסמה",
"title": "משתמש"
- }
+ },
+ "classification": "סיווג"
},
"toast": {
"copyUrlToClipboard": "כתובת האתר המועתקת.",
@@ -261,5 +288,18 @@
"title": "404",
"desc": "דף לא נמצא"
},
- "selectItem": "בחירה:{{item}}"
+ "selectItem": "בחירה:{{item}}",
+ "readTheDocumentation": "קרא את התיעוד",
+ "list": {
+ "two": "{{0}} ו־{{1}}",
+ "many": "{{items}}, ו־{{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "אופציונלי",
+ "internalID": "המזהה הפנימי ש־Frigate משתמש בו בהגדרות ובמסד הנתונים"
+ },
+ "information": {
+ "pixels": "{{area}}px"
+ }
}
diff --git a/web/public/locales/he/components/auth.json b/web/public/locales/he/components/auth.json
index 17b28cba1..0f6caf3cf 100644
--- a/web/public/locales/he/components/auth.json
+++ b/web/public/locales/he/components/auth.json
@@ -10,6 +10,7 @@
"webUnknownError": "שגיאה לא ידועה, בדוק את הלוגים.",
"rateLimit": "חרגת מהמגבלת בקשות. נסה שוב מאוחר יותר.",
"loginFailed": "ההתחברות נכשלה"
- }
+ },
+ "firstTimeLogin": "מתחבר בפעם הראשונה? פרטי ההתחברות מודפסים בלוגים של פריגייט."
}
}
diff --git a/web/public/locales/he/components/camera.json b/web/public/locales/he/components/camera.json
index f9de9a6c1..184b192bd 100644
--- a/web/public/locales/he/components/camera.json
+++ b/web/public/locales/he/components/camera.json
@@ -41,7 +41,8 @@
"label": "מצב תאימות",
"desc": "הפעל אפשרות זו רק אם השידור החי של המצלמה שלך מציג עיוותים בצבע ויש לו קו אלכסוני בצד ימין של התמונה."
}
- }
+ },
+ "birdseye": "מבט על"
},
"edit": "ערכית קבוצת מצלמות",
"delete": {
diff --git a/web/public/locales/he/components/dialog.json b/web/public/locales/he/components/dialog.json
index 472d3d541..85353b993 100644
--- a/web/public/locales/he/components/dialog.json
+++ b/web/public/locales/he/components/dialog.json
@@ -15,7 +15,8 @@
"failed": "נכשל בהתחלת הייצוא: {{error}}",
"noVaildTimeSelected": "לא נבחר טווח זמן תקף"
},
- "success": "הייצוא הוחל בהצלחה. הצג את הקובץ בתיקייה /ייצוא."
+ "success": "הייצוא התחיל בהצלחה. ניתן לצפות בקובץ בעמוד הייצוא.",
+ "view": "תצוגה"
},
"time": {
"end": {
@@ -108,7 +109,16 @@
"button": {
"export": "ייצוא",
"markAsReviewed": "סמן כסוקר",
- "deleteNow": "מחיקה כעת"
+ "deleteNow": "מחיקה כעת",
+ "markAsUnreviewed": "סימון כלא נבדק"
}
+ },
+ "imagePicker": {
+ "selectImage": "בחר תמונה ממוזערת של אובייקט במעקב",
+ "unknownLabel": "תמונת הטריגר נשמרה",
+ "search": {
+ "placeholder": "חיפוש לפי תווית או תווית משנה…"
+ },
+ "noImages": "לא נמצאו תמונות ממוזערות עבור מצלמה זו"
}
}
diff --git a/web/public/locales/he/components/filter.json b/web/public/locales/he/components/filter.json
index 2316722ca..b11aba954 100644
--- a/web/public/locales/he/components/filter.json
+++ b/web/public/locales/he/components/filter.json
@@ -1,11 +1,11 @@
{
- "filter": "לסנן",
+ "filter": "מסנן",
"features": {
"submittedToFrigatePlus": {
"tips": "עליך תחילה לסנן לפי אובייקטים במעקב שיש להם תמונת מצב.נתיבים
קווים ועיגולים יציינו נקודות משמעותיות שבהן האובייקט במעקב נע במהלך מחזור חייו.
" + } }, "users": { "title": "משתמשים", @@ -430,7 +458,7 @@ "desc": "נהל את חשבונות המשתמשים של מופע Frigate זה." }, "addUser": "הוספת משתמש", - "updatePassword": "עדכון סיסמה", + "updatePassword": "איפוס סיסמה", "toast": { "success": { "createUser": "המשתמש {{user}} נוצר בהצלחה", @@ -450,7 +478,7 @@ "role": "הרשאות", "noUsers": "לא נמצאו משתמשים.", "changeRole": "שינוי הרשאות משתמש", - "password": "סיסמה", + "password": "איפוס סיסמה", "deleteUser": "מחיקת משתמש", "username": "שם משתמש" }, @@ -476,7 +504,16 @@ "veryStrong": "מאוד חזק" }, "match": "סיסמאות תואמות", - "notMatch": "הסיסמאות אינן תואמות." + "notMatch": "הסיסמאות אינן תואמות.", + "show": "הצג סיסמה", + "hide": "הסתר סיסמה", + "requirements": { + "title": "דרישות סיסמה:", + "length": "לפחות 8 תווים", + "uppercase": "לפחות אות גדולה אחת", + "digit": "לפחות ספרה אחת", + "special": "לפחות תו מיוחד אחד (!@#$%^&*(),.?\":{}|<>)" + } }, "newPassword": { "title": "סיסמה חדשה", @@ -486,7 +523,11 @@ } }, "usernameIsRequired": "נדרש שם משתמש", - "passwordIsRequired": "נדרשת סיסמה" + "passwordIsRequired": "נדרשת סיסמה", + "currentPassword": { + "title": "סיסמה נוכחית", + "placeholder": "הזן את הסיסמה הנוכחית שלך" + } }, "createUser": { "title": "יצירת משתמש חדש", @@ -504,7 +545,12 @@ "doNotMatch": "הסיסמאות אינן תואמות", "updatePassword": "עדכון סיסמה עבור {{username}}", "setPassword": "קבע סיסמה", - "desc": "צור סיסמה חזקה כדי לאבטח חשבון זה." + "desc": "צור סיסמה חזקה כדי לאבטח חשבון זה.", + "currentPasswordRequired": "נדרשת הסיסמה הנוכחית", + "incorrectCurrentPassword": "הסיסמה הנוכחית שגויה", + "passwordVerificationFailed": "נכשל באימות הסיסמה", + "multiDeviceWarning": "כל מכשיר אחר שבו אתה מחובר יידרש להתחבר מחדש בתוך {{refresh_time}}.", + "multiDeviceAdmin": "ניתן גם לאלץ את כל המשתמשים להתחבר מחדש באופן מיידי על־ידי החלפת מפתח ה־JWT שלך." }, "changeRole": { "title": "שינוי הרשאות משתמש", @@ -515,7 +561,8 @@ "admin": "מנהל", "adminDesc": "גישה מלאה לכל התכונות.", "viewer": "צופה", - "viewerDesc": "מוגבל לדשבורד שידור חי, סקירה, גילוי וייצוא בלבד." + "viewerDesc": "מוגבל לדשבורד שידור חי, סקירה, גילוי וייצוא בלבד.", + "customDesc": "תפקיד מותאם אישית עם גישה למצלמות מסוימות." } } } @@ -618,5 +665,454 @@ "success": "הגדרות Frigate+ נשמרו. הפעל מחדש את Frigate כדי להחיל את השינויים.", "error": "שמירת שינויי התצורה נכשלה: {{errorMessage}}" } + }, + "cameraWizard": { + "step1": { + "brandInformation": "פרטי יצרן", + "brandUrlFormat": "למצלמות עם פורמט כתובת RTSP כמו: {{exampleUrl}}", + "connectionSettings": "הגדרות חיבור", + "detectionMethod": "שיטת זיהוי זרם", + "onvifPort": "פורט ONVIF", + "probeMode": "בדיקת מצלמה", + "manualMode": "בחירה ידנית", + "detectionMethodDescription": "בדוק את המצלמה באמצעות ONVIF (אם נתמך) כדי למצוא את כתובות הזרמים שלה, או בחר ידנית את יצרן המצלמה כדי להשתמש בכתובות מוגדרות מראש.\nכדי להזין כתובת RTSP מותאמת אישית, בחר בשיטה ידנית ואז בחר \"אחר\".", + "onvifPortDescription": "במצלמות שתומכות ב-ONVIF, זה בדרך כלל 80 או 8080.", + "useDigestAuth": "שימוש באימות Digest", + "useDigestAuthDescription": "השתמש באימות HTTP Digest עבור ONVIF. בחלק מהמצלמות נדרש שם משתמש/סיסמה ייעודיים ל-ONVIF, ולא משתמש ה-Admin הרגיל.", + "errors": { + "brandOrCustomUrlRequired": "בחר יצרן מצלמה והזן Host/IP, או בחר “אחר” והזן כתובת מותאמת אישית", + "nameRequired": "שם המצלמה הוא שדה חובה", + "nameLength": "שם המצלמה חייב להיות באורך של עד 64 תווים", + "invalidCharacters": "שם המצלמה מכיל תווים לא חוקיים", + "nameExists": "שם המצלמה כבר קיים", + "customUrlRtspRequired": "כתובות מותאמות אישית חייבות להתחיל ב־\"rtsp://\". עבור זרמי מצלמה שאינם RTSP נדרשת הגדרה ידנית." + }, + "description": "הזן את פרטי המצלמה ובחר אם לבצע בדיקה למצלמה או לבחור ידנית את היצרן.", + "cameraName": "שם מצלמה", + "cameraNamePlaceholder": "לדוגמה: front_door או סקירת החצר האחורית", + "host": "HOST / כתובת IP", + "port": "פורט", + "username": "שם משתמש", + "usernamePlaceholder": "אופציונלי", + "password": "סיסמה", + "passwordPlaceholder": "אופציונלי", + "selectTransport": "בחר פרוטוקול תעבורה", + "cameraBrand": "יצרן מצלמה", + "selectBrand": "בחר יצרן מצלמה עבור תבנית כתובת ה-URL", + "customUrl": "כתובת (URL) זרם מותאמת אישית", + "customUrlPlaceholder": "rtsp://username:password@host:port/path" + }, + "step2": { + "description": "בדוק את המצלמה כדי לאתר זרמים זמינים, או הגדר ידנית את ההגדרות לפי שיטת הזיהוי שבחרת.", + "testSuccess": "בדיקת החיבור הצליחה!", + "testFailed": "בדיקת החיבור נכשלה. בדוק את הנתונים שהזנת ונסה שוב.", + "testFailedTitle": "הבדיקה נכשלה", + "streamDetails": "פרטי זרם", + "probing": "בודק מצלמה...", + "retry": "נסה שוב", + "testing": { + "probingMetadata": "בודק את נתוני המטא של המצלמה…", + "fetchingSnapshot": "שולף תמונת מצב מהמצלמה…" + }, + "probeFailed": "בדיקת המצלמה נכשלה: {{error}}", + "probingDevice": "בודק את ההתקן…", + "probeSuccessful": "הבדיקה הצליחה", + "probeError": "בדיקה נכשלה", + "probeNoSuccess": "הבדיקה לא הצליחה", + "deviceInfo": "מידע על ההתקן", + "manufacturer": "יצרן", + "model": "דגם", + "firmware": "קושחה", + "profiles": "פרופילים", + "ptzSupport": "תמיכה ב-PTZ", + "autotrackingSupport": "תמיכה ב-Autotracking", + "presets": "פריסטים", + "rtspCandidates": "כתובות RTSP מוצעות", + "rtspCandidatesDescription": "כתובות ה־RTSP הבאות נמצאו בבדיקת המצלמה. בצע בדיקת חיבור כדי לצפות בנתוני הזרם (Metadata).", + "noRtspCandidates": "לא נמצאו כתובות RTSP מהמצלמה. ייתכן שפרטי ההתחברות שגויים, או שהמצלמה לא תומכת ב-ONVIF, או שהשיטה שבה השתמשנו לשליפת כתובות RTSP אינה נתמכת. חזור אחורה והזן את כתובת ה-RTSP ידנית.", + "candidateStreamTitle": "אפשרות {{number}}", + "useCandidate": "השתמש", + "uriCopy": "העתק", + "uriCopied": "הכתובת (URI) הועתקה ללוח", + "testConnection": "בדיקת חיבור", + "toggleUriView": "לחץ כדי להציג/להסתיר את הכתובת המלאה", + "connected": "מחובר", + "notConnected": "לא מחובר", + "errors": { + "hostRequired": "כתובת Host/IP היא שדה חובה" + } + }, + "step3": { + "description": "הגדר תפקידי זרם (Roles) והוסף זרמים נוספים למצלמה שלך.", + "streamsTitle": "זרמי מצלמה", + "addStream": "הוסף זרם", + "addAnotherStream": "הוסף זרם נוסף", + "streamTitle": "זרם {{number}}", + "streamUrl": "כתובת הזרם (URL)", + "selectStream": "בחר זרם", + "searchCandidates": "חיפוש אפשרויות…", + "noStreamFound": "לא נמצא זרם", + "url": "URL", + "resolution": "רזולוציה", + "selectResolution": "בחר רזולוציה", + "quality": "איכות", + "selectQuality": "בחר איכות", + "roles": "תפקידים", + "roleLabels": { + "detect": "זיהוי אובייקטים", + "record": "הקלטה", + "audio": "קול (Audio)" + }, + "testStream": "בדיקת חיבור", + "testSuccess": "בדיקת הזרם הצליחה!", + "testFailed": "בדיקת הזרם נכשלה", + "testFailedTitle": "הבדיקה נכשלה", + "connected": "מחובר", + "notConnected": "לא מחובר", + "featuresTitle": "תכונות", + "go2rtc": "הפחתת חיבורים למצלמה", + "detectRoleWarning": "כדי להמשיך, לפחות זרם אחד חייב להיות עם ייעוד \"detect\".", + "rolesPopover": { + "title": "ייעודי הזרם", + "detect": "הזרם הראשי לזיהוי אובייקטים.", + "record": "שומר קטעים מזרם הווידאו לפי הגדרות התצורה.", + "audio": "זרם לזיהוי מבוסס אודיו." + }, + "featuresPopover": { + "title": "תכונות הזרם", + "description": "השתמש ב־go2rtc לריסטרים (Restream) כדי להפחית את מספר החיבורים למצלמה שלך." + }, + "streamUrlPlaceholder": "rtsp://username:password@host:port/path" + }, + "step4": { + "description": "אימות וניתוח סופיים לפני שמירת המצלמה החדשה. התחבר לכל זרם לפני השמירה.", + "validationTitle": "אימות הזרם", + "connectAllStreams": "התחברות לכל הזרמים", + "reconnectionSuccess": "חיבור מחדש הצליח.", + "reconnectionPartial": "חלק מהזרמים לא הצליחו להתחבר מחדש.", + "streamUnavailable": "תצוגה מקדימה של הזרם אינה זמינה", + "reload": "טעינה מחדש", + "connecting": "מתחבר...", + "streamTitle": "זרם {{number}}", + "valid": "תקין", + "failed": "נכשל", + "notTested": "לא נבדק", + "connectStream": "התחבר", + "connectingStream": "מתחבר", + "disconnectStream": "נתק", + "estimatedBandwidth": "רוחב־פס משוער", + "roles": "ייעודים", + "ffmpegModule": "שימוש במצב תאימות לזרם", + "ffmpegModuleDescription": "אם הזרם לא נטען אחרי כמה ניסיונות, נסה להפעיל את זה. כשהאפשרות פעילה, Frigate ישתמש במודול ffmpeg יחד עם go2rtc. זה עשוי לשפר תאימות עם זרמים של חלק מהמצלמות.", + "none": "ללא", + "error": "שגיאה", + "streamValidated": "הזרם {{number}} אומת בהצלחה", + "streamValidationFailed": "אימות הזרם {{number}} נכשל", + "saveAndApply": "שמירת מצלמה חדשה", + "saveError": "תצורה לא תקינה. בדוק את ההגדרות שלך.", + "issues": { + "title": "אימות הזרם", + "videoCodecGood": "קידוד הווידאו הוא {{codec}}.", + "audioCodecGood": "קידוד האודיו הוא {{codec}}.", + "resolutionHigh": "רזולוציה של {{resolution}} עשויה לגרום לשימוש מוגבר במשאבים.", + "resolutionLow": "רזולוציה של {{resolution}} עשויה להיות נמוכה מדי לזיהוי אמין של אובייקטים קטנים.", + "noAudioWarning": "לא זוהה אודיו בזרם הזה, ולכן ההקלטות יהיו ללא שמע.", + "audioCodecRecordError": "כדי לכלול אודיו בהקלטות נדרש קידוד שמע AAC.", + "audioCodecRequired": "כדי לאפשר זיהוי אודיו נדרש זרם שמע.", + "restreamingWarning": "הפחתת מספר החיבורים למצלמה עבור זרם ההקלטה (record) עשויה להעלות מעט את השימוש ב־CPU.", + "brands": { + "reolink-rtsp": "RTSP של Reolink לא מומלץ. הפעל HTTP בהגדרות הקושחה של המצלמה, ואז הפעל מחדש את אשף ההגדרה.", + "reolink-http": "בזרמי HTTP של Reolink מומלץ להשתמש ב־FFmpeg לתאימות טובה יותר. הפעל עבור הזרם הזה את האפשרות “שימוש במצב תאימות לזרם”." + }, + "dahua": { + "substreamWarning": "זרם משנה 1 נעול לרזולוציה נמוכה. מצלמות רבות של Dahua / Amcrest / EmpireTech תומכות בזרמי משנה נוספים שצריך להפעיל בהגדרות המצלמה מומלץ לבדוק אם קיימים זרמי משנה כאלה ולהשתמש בהם במידה וזמינים." + }, + "hikvision": { + "substreamWarning": "זרם משנה 1 נעול לרזולוציה נמוכה. מצלמות רבות של Hikvision תומכות בזרמי משנה נוספים שצריך להפעיל בהגדרות המצלמה. מומלץ לבדוק אם קיימים זרמי משנה כאלה ולהשתמש בהם, אם הם זמינים." + } + } + }, + "title": "הוסף מצלמה", + "description": "בצע את השלבים הבאים כדי להוסיף מצלמה חדשה להתקנת ה־Frigate שלך.", + "steps": { + "nameAndConnection": "שם וחיבור", + "probeOrSnapshot": "בדיקה (Probe) או צילום תמונה (Snapshot)", + "streamConfiguration": "הגדרות זרם", + "validationAndTesting": "אימות ובדיקה" + }, + "save": { + "success": "המצלמה החדשה {{cameraName}} נשמרה בהצלחה.", + "failure": "שגיאה בשמירת {{cameraName}}." + }, + "testResultLabels": { + "resolution": "רזולוציה", + "video": "וידיאו", + "audio": "אודיו", + "fps": "FPS" + }, + "commonErrors": { + "noUrl": "אנא ספק כתובת URL תקינה לזרם", + "testFailed": "בדיקת הזרם נכשלה: {{error}}" + } + }, + "cameraManagement": { + "title": "ניהול מצלמות", + "addCamera": "הוספת מצלמה חדשה", + "editCamera": "עריכת מצלמה:", + "selectCamera": "בחירת מצלמה", + "backToSettings": "חזרה להגדרות מצלמה", + "streams": { + "title": "הפעלה / השבתה של מצלמות", + "desc": "השבת מצלמה זמנית עד ש־Frigate יופעל מחדש. השבתת מצלמה עוצרת לחלוטין את העיבוד של Frigate עבור זרמי המצלמה הזו. זיהוי, הקלטה וניפוי שגיאות לא יהיו זמינים.{{label}}?",
+ "ask_an": "Da li je ovaj objekt {{label}}?",
+ "ask_full": "Da li je ovaj objekt {{untranslatedLabel}} ({{translatedLabel}})?"
+ },
+ "state": {
+ "submitted": "Poslano"
+ }
+ }
+ },
+ "video": {
+ "viewInHistory": "Pogledaj u povijesti"
+ }
+ },
+ "export": {
+ "time": {
+ "lastHour_one": "Zadnji sat",
+ "lastHour_few": "Zadnja {{count}} sata",
+ "lastHour_other": "Zadnjih {{count}} sati",
+ "start": {
+ "title": "Vrijeme početka",
+ "label": "Odaberi vrijeme početka"
+ },
+ "end": {
+ "title": "Vrijeme kraja",
+ "label": "Odaberi vrijeme kraja"
+ },
+ "fromTimeline": "Izaberi sa vremenske crte",
+ "custom": "Prilagođeno"
+ },
+ "name": {
+ "placeholder": "Imenuj Izvoz"
+ },
+ "select": "Odaberi",
+ "export": "Izvoz",
+ "selectOrExport": "Odaberi ili Izvezi",
+ "toast": {
+ "success": "Izvoz je uspješno pokrenut. Datoteku možete pregledati na stranici za izvoz.",
+ "view": "Prikaz",
+ "error": {
+ "failed": "Nije uspjelo pokretanje izvoza: {{error}}",
+ "endTimeMustAfterStartTime": "Vrijeme završetka mora biti nakon vremena početka",
+ "noVaildTimeSelected": "Nema odabranog valjanog vremenskog raspona"
+ }
+ },
+ "fromTimeline": {
+ "saveExport": "Spremi Izvoz",
+ "previewExport": "Pregledaj Izvoz"
+ }
+ },
+ "streaming": {
+ "label": "Emitiraj",
+ "restreaming": {
+ "disabled": "Ponovno emitiranje nije omogućeno za ovu kameru.",
+ "desc": {
+ "title": "Postavi go2rtc za opcije dodatnog prikaza uživo i zvuk za ovu kameru."
+ }
+ },
+ "showStats": {
+ "label": "Pokaži statistike emitiranja",
+ "desc": "Omogući ovu opciju za prikaz statistike emitiranja kao proziran prozor na slici kamere."
+ },
+ "debugView": "Debug Prikaz"
+ },
+ "search": {
+ "saveSearch": {
+ "label": "Spremi Pretragu",
+ "desc": "Dodaj ime za ovu spremljenu pretragu.",
+ "placeholder": "Unesi ime za svoju pretragu",
+ "overwrite": "{{searchName}} već postoji. Spremanje će prepisati postojeću vrijednost.",
+ "success": "Pretraga ({{searchName}}) je spremljena.",
+ "button": {
+ "save": {
+ "label": "Spremi ovu pretragu"
+ }
+ }
+ }
+ },
+ "recording": {
+ "confirmDelete": {
+ "title": "Potvrdi Brisanje",
+ "desc": {
+ "selected": "Jeste li sigurni da želite izbrisati sav snimljen video povezan s ovom preglednom stavkom?detect stream-a, provjeri logove"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "Kadar je uspješno poslan u Frigate+"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "Neuspješno slanje kadra u Frigate+"
+ }
+ }
+}
diff --git a/web/public/locales/hr/objects.json b/web/public/locales/hr/objects.json
new file mode 100644
index 000000000..955ebe0cd
--- /dev/null
+++ b/web/public/locales/hr/objects.json
@@ -0,0 +1,120 @@
+{
+ "person": "Osoba",
+ "bicycle": "Bicikl",
+ "car": "Automobil",
+ "motorcycle": "Motocikl",
+ "airplane": "Zrakoplov",
+ "bus": "Autobus",
+ "train": "Vlak",
+ "boat": "ÄŒamac",
+ "traffic_light": "Semafor",
+ "fire_hydrant": "Hidrant",
+ "street_sign": "Prometni znak",
+ "stop_sign": "Znak stop",
+ "bench": "Klupa",
+ "bird": "Ptica",
+ "cat": "MaÄka",
+ "dog": "Pas",
+ "horse": "Konj",
+ "sheep": "Ovca",
+ "cow": "Krava",
+ "parking_meter": "Parkirni Automat",
+ "elephant": "Slon",
+ "bear": "Medvjed",
+ "zebra": "Zebra",
+ "giraffe": "Žirafa",
+ "hat": "Kapa",
+ "backpack": "Ruksak",
+ "umbrella": "Kišobran",
+ "shoe": "Cipela",
+ "eye_glasses": "Naočale",
+ "handbag": "Ručna torba",
+ "tie": "Kravata",
+ "suitcase": "Kovčeg",
+ "frisbee": "Frizbi",
+ "skis": "Skije",
+ "snowboard": "Snowboard",
+ "sports_ball": "Sportska Lopta",
+ "kite": "Zmaj",
+ "baseball_bat": "Baseball Palica",
+ "baseball_glove": "Baseball Rukavica",
+ "skateboard": "Skejtboard",
+ "surfboard": "Daska za surfanje",
+ "tennis_racket": "Teniski reket",
+ "bottle": "Boca",
+ "plate": "Tanjur",
+ "wine_glass": "Vinska Čaša",
+ "cup": "Šalica",
+ "fork": "Vilica",
+ "knife": "Nož",
+ "spoon": "Žlica",
+ "bowl": "Zdjela",
+ "banana": "Banana",
+ "apple": "Jabuka",
+ "sandwich": "Sendvič",
+ "orange": "Naranča",
+ "broccoli": "Brokula",
+ "carrot": "Mrkva",
+ "hot_dog": "Hot Dog",
+ "pizza": "Pizza",
+ "donut": "Krafna",
+ "cake": "Torta",
+ "chair": "Stolica",
+ "couch": "Kauč",
+ "potted_plant": "Biljka u Loncu",
+ "bed": "Krevet",
+ "mirror": "Ogledalo",
+ "dining_table": "Blagovaonski Stol",
+ "window": "Prozor",
+ "desk": "Radni Stol",
+ "toilet": "WC",
+ "door": "Vrata",
+ "tv": "TV",
+ "laptop": "Laptop",
+ "mouse": "Miš",
+ "remote": "Daljinski",
+ "keyboard": "Tipkovnica",
+ "cell_phone": "Mobilni Telefon",
+ "microwave": "Mikrovalna",
+ "oven": "Pećnica",
+ "toaster": "Toster",
+ "sink": "Sudoper",
+ "refrigerator": "Frižider",
+ "blender": "Blender",
+ "book": "Knjiga",
+ "clock": "Sat",
+ "vase": "Vaza",
+ "scissors": "Škare",
+ "teddy_bear": "Plišani Medo",
+ "hair_dryer": "Fen",
+ "toothbrush": "Četkica za zube",
+ "hair_brush": "Četka za kosu",
+ "vehicle": "Vozilo",
+ "squirrel": "Vjeverica",
+ "deer": "Jelen",
+ "animal": "Životinja",
+ "bark": "Kora",
+ "fox": "Lisica",
+ "goat": "Koza",
+ "rabbit": "Zec",
+ "raccoon": "Rakun",
+ "robot_lawnmower": "Robotska Kosilica",
+ "waste_bin": "Kanta za smeće",
+ "on_demand": "Na Zahtjev",
+ "face": "Lice",
+ "license_plate": "Registracijska oznaka",
+ "package": "Paket",
+ "bbq_grill": "Roštilj",
+ "amazon": "Amazon",
+ "usps": "USPS",
+ "ups": "UPS",
+ "fedex": "FedEx",
+ "dhl": "DHL",
+ "an_post": "An Post",
+ "purolator": "Purolator",
+ "postnl": "PostNL",
+ "nzpost": "NZPost",
+ "postnord": "PostNord",
+ "gls": "GLS",
+ "dpd": "DPD"
+}
diff --git a/web/public/locales/hr/views/classificationModel.json b/web/public/locales/hr/views/classificationModel.json
new file mode 100644
index 000000000..97bfff234
--- /dev/null
+++ b/web/public/locales/hr/views/classificationModel.json
@@ -0,0 +1,192 @@
+{
+ "documentTitle": "Klasifikacijski modeli - Frigate",
+ "button": {
+ "deleteImages": "Obriši slike",
+ "trainModel": "Treniraj model",
+ "addClassification": "Dodaj klasifikaciju",
+ "deleteModels": "Obriši modele",
+ "editModel": "Uredi model",
+ "deleteClassificationAttempts": "Izbriši Klasifikacijske Slike",
+ "renameCategory": "Preimenuj klasu",
+ "deleteCategory": "Izbriši Klasu"
+ },
+ "tooltip": {
+ "trainingInProgress": "Model se trenutno trenira",
+ "modelNotReady": "Model nije spreman za treniranje",
+ "noNewImages": "Nema novih slika za treniranje. Prvo klasificirajte više slika u skupu podataka.",
+ "noChanges": "Nema promjena u skupu podataka od posljednjeg treniranja."
+ },
+ "details": {
+ "unknown": "Nepoznato",
+ "none": "Nema",
+ "scoreInfo": "Rezultat predstavlja prosječnu klasifikacijsku pouzdanost kroz sve detekcije ovog objekta."
+ },
+ "toast": {
+ "success": {
+ "deletedImage": "Obrisane slike",
+ "deletedCategory": "Izbrisana Klasa",
+ "deletedModel_one": "Uspješno izbrisan {{count}} model",
+ "deletedModel_few": "Uspješno izbrisana {{count}} modela",
+ "deletedModel_other": "Uspješno izbrisano {{count}} modela",
+ "categorizedImage": "Uspješno klasificirana slika",
+ "trainedModel": "Uspješno treniran model.",
+ "trainingModel": "Uspješno započeto treniranje modela.",
+ "updatedModel": "Uspješno ažurirana konfiguracija modela",
+ "renamedCategory": "Uspješno preimenovana klasa na {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Neuspješno brisanje: {{errorMessage}}",
+ "deleteCategoryFailed": "Neuspješno brisanje klase: {{errorMessage}}",
+ "deleteModelFailed": "Nije uspjelo brisanje modela: {{errorMessage}}",
+ "categorizeFailed": "Nije uspjelo kategoriziranje slike: {{errorMessage}}",
+ "trainingFailed": "Neuspješno treniranje modela. Provjerite Frigate zapisnike za detalje.",
+ "trainingFailedToStart": "Neuspješno pokretanje treniranja modela: {{errorMessage}}",
+ "updateModelFailed": "Neuspješno ažuriranje modela: {{errorMessage}}",
+ "renameCategoryFailed": "Neuspješno preimenovanje klase: {{errorMessage}}"
+ }
+ },
+ "description": {
+ "invalidName": "Nevaljano ime. Ime može samo uključivati slova, brojeve, razmake, navodnike, podcrte i crtice."
+ },
+ "train": {
+ "titleShort": "Nedavno",
+ "aria": "Odaberi Nedavne Klasifikacije",
+ "title": "Nedavne Klasifikacije"
+ },
+ "deleteModel": {
+ "desc_one": "Jeste li sigurni da želite izbrisati {{count}} model? Ovo će trajno izbrisati sve povezane podatke, uključujući slike i podatke za treniranje. Ova radnja se ne može poništiti.",
+ "desc_few": "Jeste li sigurni da želite izbrisati {{count}} modela? Ovo će trajno izbrisati sve povezane podatke, uključujući slike i podatke za treniranje. Ova radnja se ne može poništiti.",
+ "desc_other": "Jeste li sigurni da želite izbrisati {{count}} modela? Ovo će trajno izbrisati sve povezane podatke, uključujući slike i podatke za treniranje. Ova radnja se ne može poništiti.",
+ "title": "Izbriši klasifikacijski model",
+ "single": "Jesi li siguran da želiš izbrisati {{name}}? To će trajno izbrisati sve povezane podatke, uključujući slike i podatke za treniranje. Ova radnja se ne može poništiti."
+ },
+ "deleteDatasetImages": {
+ "desc_one": "Jeste li sigurni da želite izbrisati {{count}} sliku iz {{dataset}}? Ova radnja se ne može poništiti i zahtijevat će ponovno treniranje modela.",
+ "desc_few": "Jeste li sigurni da želite izbrisati {{count}} slike iz {{dataset}}? Ova radnja se ne može poništiti i zahtijevat će ponovno treniranje modela.",
+ "desc_other": "Jeste li sigurni da želite izbrisati {{count}} slika iz {{dataset}}? Ova radnja se ne može poništiti i zahtijevat će ponovno treniranje modela.",
+ "title": "Izbriši slike iz skupa podataka"
+ },
+ "deleteTrainImages": {
+ "desc_one": "Jeste li sigurni da želite izbrisati {{count}} sliku? Ova radnja se ne može poništiti.",
+ "desc_few": "Jeste li sigurni da želite izbrisati {{count}} slike? Ova radnja se ne može poništiti.",
+ "desc_other": "Jeste li sigurni da želite izbrisati {{count}} slika? Ova radnja se ne može poništiti.",
+ "title": "Izbriši slike iz skupa za treniranje"
+ },
+ "wizard": {
+ "step3": {
+ "allImagesRequired_one": "Molimo klasificirajte sve slike. Preostala je {{count}} slika.",
+ "allImagesRequired_few": "Molimo klasificirajte sve slike. Preostale su {{count}} slike.",
+ "allImagesRequired_other": "Molimo klasificirajte sve slike. Preostalo je {{count}} slika.",
+ "selectImagesPrompt": "Odaberite sve slike s: {{className}}",
+ "selectImagesDescription": "Kliknite na slike za odabir. Kliknite Nastavi kada završite s ovom klasom.",
+ "generating": {
+ "title": "Generiranje Primjeraka Slika",
+ "description": "Frigate povlači reprezentativne slike iz vaših snimaka. Ovo može potrajati..."
+ },
+ "training": {
+ "title": "Treniranje Modela",
+ "description": "Vaš model se trenira u pozadini. Zatvorite ovaj dijalog, a model će početi raditi čim treniranje završi."
+ },
+ "retryGenerate": "Ponovi Generiranje",
+ "noImages": "Nema generiranih primjeraka slika",
+ "classifying": "Klasificiranje & Treniranje...",
+ "trainingStarted": "Treniranje je uspješno pokrenuto",
+ "modelCreated": "Model je uspješno kreiran. Koristite prikaz Nedavnih Klasifikacija za dodavanje slika za nedostajuća stanja, a zatim trenirajte model.",
+ "errors": {
+ "noCameras": "Nema konfiguriranih kamera",
+ "noObjectLabel": "Nije odabrana oznaka objekta",
+ "generateFailed": "Neuspjelo generiranje primjera: {{error}}",
+ "generationFailed": "Generiranje nije uspjelo. Pokušajte ponovo.",
+ "classifyFailed": "Neuspjela klasifikacija slika: {{error}}"
+ },
+ "generateSuccess": "Primjerci slika su uspješno generirani",
+ "missingStatesWarning": {
+ "title": "Nedostaju Primjeri Stanja",
+ "description": "Preporučuje se odabrati primjere za sva stanja radi najboljih rezultata. Možete nastaviti bez odabira svih stanja, ali model neće biti treniran dok svi statusi nemaju slike. Nakon nastavka, koristite prikaz Nedavnih Klasifikacija za klasifikaciju slika za nedostajuća stanja, a zatim trenirajte model."
+ }
+ },
+ "title": "Kreiraj Novu Klasifikaciju",
+ "steps": {
+ "nameAndDefine": "Naziv & Definicija",
+ "stateArea": "Područje Stanja",
+ "chooseExamples": "Odaberi Primjere"
+ },
+ "step1": {
+ "description": "Modeli stanja prate fiksna područja kamere za promjene (npr. vrata otvorena/zatvorena). Modeli objekata dodaju klasifikacije detektiranim objektima (npr. poznate životinje, dostavljači, itd.).",
+ "name": "Naziv",
+ "namePlaceholder": "Unesite naziv modela...",
+ "type": "Tip",
+ "typeState": "Stanje",
+ "typeObject": "Objekt",
+ "objectLabel": "Oznaka Objekta",
+ "objectLabelPlaceholder": "Odaberi tip objekta...",
+ "classificationType": "Tip Klasifikacije",
+ "classificationTypeTip": "Saznaj više o tipovima klasifikacije",
+ "classificationTypeDesc": "Podoznake dodaju dodatni tekst na oznaku objekta (npr. 'Osoba: UPS'). Atributi su pretraživi metapodaci pohranjeni zasebno u metapodacima objekta.",
+ "classificationSubLabel": "Podoznaka",
+ "classificationAttribute": "Atribut",
+ "classes": "Klase",
+ "states": "Stanja",
+ "classesTip": "Saznaj više o klasama",
+ "classesStateDesc": "Definiraj različita stanja u kojima područje kamere može biti. Na primjer: 'otvoreno' i 'zatvoreno' za garažna vrata.",
+ "classesObjectDesc": "Definiraj različite kategorije za klasifikaciju detektiranih objekata. Na primjer: 'dostavljač', 'stanar', 'nepoznata osoba' za klasifikaciju ljudi.",
+ "classPlaceholder": "Unesite naziv klase...",
+ "errors": {
+ "nameRequired": "Naziv modela je obavezan",
+ "nameLength": "Naziv modela mora imati najviše 64 znaka",
+ "nameOnlyNumbers": "Naziv modela ne smije sadržavati samo brojeve",
+ "classRequired": "Potrebna je barem 1 klasa",
+ "classesUnique": "Nazivi klasa moraju biti jedinstveni",
+ "noneNotAllowed": "Klasa 'none' nije dopuštena",
+ "stateRequiresTwoClasses": "Modeli stanja zahtijevaju najmanje 2 klase",
+ "objectLabelRequired": "Molimo odaberite oznaku objekta",
+ "objectTypeRequired": "Molimo odaberite tip klasifikacije"
+ }
+ },
+ "step2": {
+ "description": "Odaberite kamere i definirajte područje praćenja za svaku kameru. Model će klasificirati stanje tih područja.",
+ "cameras": "Kamere",
+ "selectCamera": "Odaberi Kameru",
+ "noCameras": "Kliknite + za dodavanje kamera",
+ "selectCameraPrompt": "Odaberite kameru s popisa kako biste definirali područje praćenja"
+ }
+ },
+ "deleteCategory": {
+ "title": "Izbriši klasu",
+ "desc": "Jesi li siguran da želiš izbrisati klasu {{name}}? To će trajno izbrisati sve povezane slike i zahtijevati ponovno treniranje modela.",
+ "minClassesTitle": "Nije moguće izbrisati klasu",
+ "minClassesDesc": "Model klasifikacije mora imati barem 2 klase. Dodaj još jednu klasu prije brisanja ove."
+ },
+ "edit": {
+ "title": "Uredi model klasifikacije",
+ "descriptionState": "Uredi klase za ovaj model klasifikacije stanja. Promjene zahtijevaju ponovno treniranje modela.",
+ "descriptionObject": "Uredi tip objekta i tip klasifikacije za ovaj model klasifikacije objekata.",
+ "stateClassesInfo": "Napomena: Promjena klasa stanja zahtijeva ponovno treniranje modela s ažuriranim klasama."
+ },
+ "renameCategory": {
+ "title": "Preimenuj klasu",
+ "desc": "Unesite novi naziv za {{name}}. Bit će potrebno ponovno trenirati model da promjena naziva stupi na snagu."
+ },
+ "categories": "Klase",
+ "createCategory": {
+ "new": "Kreiraj Novu Klasu"
+ },
+ "categorizeImageAs": "Klasificiraj Sliku Kao:",
+ "categorizeImage": "Klasificiraj Sliku",
+ "menu": {
+ "objects": "Objekti",
+ "states": "Stanja"
+ },
+ "noModels": {
+ "object": {
+ "title": "Nema Modela Klasifikacije Objekata",
+ "description": "Kreiraj prilagođeni model za klasifikaciju detektiranih objekata.",
+ "buttonText": "Kreiraj Model Objekta"
+ },
+ "state": {
+ "title": "Nema Modela Klasifikacije Stanja",
+ "description": "Kreiraj prilagođeni model za praćenje i klasifikaciju promjena stanja u određenim područjima kamere.",
+ "buttonText": "Kreiraj Model Stanja"
+ }
+ }
+}
diff --git a/web/public/locales/hr/views/configEditor.json b/web/public/locales/hr/views/configEditor.json
new file mode 100644
index 000000000..1a5f2d23e
--- /dev/null
+++ b/web/public/locales/hr/views/configEditor.json
@@ -0,0 +1,18 @@
+{
+ "documentTitle": "Uređivač konfiguracije - Frigate",
+ "copyConfig": "Kopiraj konfiguraciju",
+ "saveAndRestart": "Spremi i pokreni ponovno",
+ "saveOnly": "Samo spremi",
+ "confirm": "Izađi bez spremanja?",
+ "toast": {
+ "error": {
+ "savingError": "Greška pri spremanju konfiguracije"
+ },
+ "success": {
+ "copyToClipboard": "Konfiguracija je kopirana u međuspremnik."
+ }
+ },
+ "configEditor": "Uređivač konfiguracije",
+ "safeModeDescription": "Frigate je u sigurnom načinu zbog greške u validaciji konfiguracije.",
+ "safeConfigEditor": "Uređivač konfiguracije (Siguran Način)"
+}
diff --git a/web/public/locales/hr/views/events.json b/web/public/locales/hr/views/events.json
new file mode 100644
index 000000000..3bafeee22
--- /dev/null
+++ b/web/public/locales/hr/views/events.json
@@ -0,0 +1,65 @@
+{
+ "alerts": "Upozorenja",
+ "detections": "Detekcije",
+ "motion": {
+ "label": "Kretnja",
+ "only": "Samo kretnje"
+ },
+ "allCameras": "Sve kamere",
+ "empty": {
+ "alert": "Nema uzbuna za pregledati",
+ "detection": "Nema detekcija za pregled",
+ "motion": "Nema podataka o pokretu",
+ "recordingsDisabled": {
+ "title": "Snimanja moraju biti uključena",
+ "description": "Stavke za pregled mogu biti stvorene za kameru jedino kada su snimanja uključena za tu kameru."
+ }
+ },
+ "timeline": "Vremenska linija",
+ "timeline.aria": "Odaberi vremensku liniju",
+ "zoomOut": "Udalji",
+ "events": {
+ "label": "Događaji",
+ "aria": "Odaberi događaje",
+ "noFoundForTimePeriod": "Nema pronađenih događaja za ovaj vremenski period."
+ },
+ "zoomIn": "Približi",
+ "detail": {
+ "label": "Detalji",
+ "noDataFound": "Nema detaljnih podataka za pregled",
+ "aria": "Uključi/isključi prikaz detalja",
+ "trackedObject_one": "{{count}} objekt",
+ "trackedObject_other": "{{count}} objekta",
+ "noObjectDetailData": "Nema dostupnih detaljnih podataka o objektu.",
+ "settings": "Postavke detaljnog prikaza",
+ "alwaysExpandActive": {
+ "title": "Uvijek proširi aktivno",
+ "desc": "Uvijek proširite detalje objekta aktivnog pregledanog stavka kada su dostupni."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Praćena točka",
+ "clickToSeek": "Kliknite za pomicanje na ovo vrijeme"
+ },
+ "documentTitle": "Pregled - Frigate",
+ "recordings": {
+ "documentTitle": "Snimke - Frigate"
+ },
+ "calendarFilter": {
+ "last24Hours": "Zadnja 24 sata"
+ },
+ "markAsReviewed": "Označi kao Pregledano",
+ "markTheseItemsAsReviewed": "Označi ove stavke kao pregledane",
+ "newReviewItems": {
+ "label": "Pogledaj nove stavke za pregled",
+ "button": "Nove stavke za pregled"
+ },
+ "selected_one": "{{count}} odabran",
+ "selected_other": "{{count}} odabrano",
+ "select_all": "Sve",
+ "camera": "Kamera",
+ "detected": "detektirano",
+ "normalActivity": "Normalno",
+ "needsReview": "Potreban pregled",
+ "securityConcern": "Sigurnosna zabrinutost"
+}
diff --git a/web/public/locales/hr/views/explore.json b/web/public/locales/hr/views/explore.json
new file mode 100644
index 000000000..fce8024cf
--- /dev/null
+++ b/web/public/locales/hr/views/explore.json
@@ -0,0 +1,250 @@
+{
+ "documentTitle": "Istražite - Frigate",
+ "generativeAI": "Generativni AI",
+ "exploreIsUnavailable": {
+ "title": "Istraživanje je nedostupno",
+ "embeddingsReindexing": {
+ "startingUp": "Pokretanje…",
+ "finishingShortly": "Završava uskoro",
+ "estimatedTime": "Procjenjeno preostalo vrijeme:",
+ "context": "Istraživanje se može koristiti nakon što je završeno ponovno indeksiranje ugrađivanja praćenih objekata.",
+ "step": {
+ "thumbnailsEmbedded": "Ugrađene sličice: ",
+ "descriptionsEmbedded": "Ugrađeni opisi: ",
+ "trackedObjectsProcessed": "Procesirani praćeni objekti: "
+ }
+ },
+ "downloadingModels": {
+ "setup": {
+ "textModel": "Tekstualni model",
+ "visionModel": "Model za vid",
+ "visionModelFeatureExtractor": "Ekstraktor značajki modela vizije",
+ "textTokenizer": "Tokenizator teksta"
+ },
+ "context": "Frigate preuzima potrebne modele ugrađivanja kako bi podržao značajku semantičkog pretraživanja. To može potrajati nekoliko minuta, ovisno o brzini vaše mrežne veze.",
+ "tips": {
+ "context": "Možda ćete htjeti ponovno indeksirati ugrađivanja (embeddings) svojih praćenih objekata kada se modeli preuzmu."
+ },
+ "error": "Došlo je do pogreške. Provjerite Frigate logove."
+ }
+ },
+ "details": {
+ "timestamp": "Vremenska oznaka",
+ "item": {
+ "tips": {
+ "mismatch_one": "{{count}} nedostupan objekt je otkriven i uključen u ovaj pregledni stavak. Ti objekti ili nisu kvalificirani kao upozorenje ili detekcija, ili su već uklonjeni/izbrisani.",
+ "mismatch_few": "{{count}} nedostupna objekta su otkrivena i uključena u ovaj pregledni stavak. Ti objekti ili nisu kvalificirani kao upozorenje ili detekcija, ili su već uklonjeni/izbrisani.",
+ "mismatch_other": "{{count}} nedostupnih objekata je otkriveno i uključeno u ovaj pregledni stavak. Ti objekti ili nisu kvalificirani kao upozorenje ili detekcija, ili su već uklonjeni/izbrisani.",
+ "hasMissingObjects": "Prilagodite svoju konfiguraciju ako želite da Frigate sprema praćene objekte za sljedeće oznake: {{objects}}"
+ },
+ "title": "Detalji o pregledu stavke",
+ "desc": "Detalji o pregledu stavke",
+ "button": {
+ "share": "Podijelite ovaj pregled",
+ "viewInExplore": "Pogledaj u Istraži"
+ },
+ "toast": {
+ "success": {
+ "regenerate": "Zatražen je novi opis od {{provider}}. Ovisno o brzini vašeg pružatelja usluga, novi opis može trebati neko vrijeme da se regenerira.",
+ "updatedSublabel": "Uspješno ažurirana podoznaka.",
+ "updatedLPR": "Uspješno ažurirana registarska pločica.",
+ "updatedAttributes": "Uspješno ažurirani atributi.",
+ "audioTranscription": "Uspješno zatražena audio transkripcija. Ovisno o brzini vašeg Frigate servera, transkripcija može potrajati neko vrijeme."
+ },
+ "error": {
+ "regenerate": "Neuspješno pozivanje {{provider}} za novi opis: {{errorMessage}}",
+ "updatedSublabelFailed": "Nije uspjelo ažurirati podoznake: {{errorMessage}}",
+ "updatedLPRFailed": "Neuspješno ažuriranje registarske pločice: {{errorMessage}}",
+ "updatedAttributesFailed": "Neuspješno ažuriranje atributa: {{errorMessage}}",
+ "audioTranscription": "Neuspješno zatraživanje audio transkripcije: {{errorMessage}}"
+ }
+ }
+ },
+ "label": "Oznaka",
+ "editSubLabel": {
+ "title": "Uredi podoznaku",
+ "desc": "Unesite novu podoznaku za ovaj {{label}}",
+ "descNoLabel": "Unesite novu oznaku podoznake za ovaj praćeni objekt"
+ },
+ "editLPR": {
+ "title": "Uredi registarsku pločicu",
+ "desc": "Unesite novu vrijednost registarske pločice za ovaj {{label}}",
+ "descNoLabel": "Unesite novu vrijednost registarske pločice za ovaj praćeni objekt"
+ },
+ "editAttributes": {
+ "title": "Atributi uređivanja",
+ "desc": "Odaberite klasifikacijske atribute za ovaj {{label}}"
+ },
+ "snapshotScore": {
+ "label": "Ocjena snimke"
+ },
+ "topScore": {
+ "label": "Najbolja ocjena",
+ "info": "Najviša ocjena je najviši medijan za praćeni objekt, pa se može razlikovati od rezultata prikazanog na sličici rezultata pretraživanja."
+ },
+ "score": {
+ "label": "Ocjena"
+ },
+ "recognizedLicensePlate": "Priznata registarska pločica",
+ "attributes": "Klasifikacijski atributi",
+ "estimatedSpeed": "Procijenjena brzina",
+ "objects": "Objekti",
+ "camera": "Kamera",
+ "zones": "Zone",
+ "button": {
+ "findSimilar": "Pronađite slične",
+ "regenerate": {
+ "title": "Regeneriraj",
+ "label": "Ponovno generiranje opisa praćenog objekta"
+ }
+ },
+ "description": {
+ "label": "Opis",
+ "placeholder": "Opis praćenog objekta",
+ "aiTips": "Frigate neće tražiti opis od vašeg Generative AI pružatelja dok životni ciklus praćenog objekta ne završi."
+ },
+ "expandRegenerationMenu": "Proširi izbornik regeneracije",
+ "regenerateFromSnapshot": "Regeneracija iz Snimki",
+ "regenerateFromThumbnails": "Regeneracija iz sličica",
+ "tips": {
+ "descriptionSaved": "Uspješno spremljen opis",
+ "saveDescriptionFailed": "Nije ažuriran opis: {{errorMessage}}"
+ },
+ "title": {
+ "label": "Naslov"
+ }
+ },
+ "trackedObjectDetails": "Detalji praćenog objekta",
+ "type": {
+ "details": "detalji",
+ "snapshot": "snimka",
+ "thumbnail": "Sličica",
+ "video": "video",
+ "tracking_details": "detalji praćenja"
+ },
+ "exploreMore": "Istraži više {{label}} objekata",
+ "trackingDetails": {
+ "title": "Detalji Praćenja",
+ "noImageFound": "Slika nije nađena za ovaj vremenski zapis.",
+ "createObjectMask": "Napravi Masku Objekta",
+ "adjustAnnotationSettings": "Podesi postavke anotacije",
+ "scrollViewTips": "Kliknite za prikaz značajnih trenutaka životnog ciklusa ovog objekta.",
+ "autoTrackingTips": "Pozicije ograničavajućih okvira bit će netočne za kamere s automatskim praćenjem.",
+ "count": "{{first}} of {{second}}",
+ "trackedPoint": "Praćena točka",
+ "lifecycleItemDesc": {
+ "visible": "{{label}} detektiran",
+ "entered_zone": "{{label}} ušlo u {{zones}}",
+ "active": "{{label}} postao aktivan",
+ "stationary": "{{label}} je postao stacionaran",
+ "attribute": {
+ "faceOrLicense_plate": "{{attribute}} detektiran za {{label}}",
+ "other": "{{label}} prepoznat kao {{attribute}}"
+ },
+ "gone": "{{label}} lijevo",
+ "heard": "{{label}} zvuk detektiran",
+ "external": "{{label}} detektiran",
+ "header": {
+ "zones": "Zone",
+ "ratio": "Omjer",
+ "area": "Površina",
+ "score": "Ocjena"
+ }
+ },
+ "annotationSettings": {
+ "title": "Postavke anotacija",
+ "showAllZones": {
+ "title": "Pokaži sve zone",
+ "desc": "Uvijek prikaži zone u okvirima gdje su objekti ušli u zonu."
+ },
+ "offset": {
+ "label": "Pomak anotacija",
+ "desc": "Ovi podaci dolaze s detekcijskog emitiranja vaše kamere, ali se prikazuju preko slika iz snimajućeg emitiranja. Malo je vjerojatno da su oba emitiranja potpuno sinkronizirana. Kao rezultat toga, okvir (bounding box) i snimka možda neće savršeno odgovarati. Ovom postavkom možete pomaknuti oznake unaprijed ili unatrag u vremenu kako bi bolje odgovarale snimljenoj snimci.",
+ "millisecondsToOffset": "Milisekunde za pomicanje detekcije anotacija za. Zadano: 0",
+ "tips": "Smanjite vrijednost ako je reprodukcija videa ispred kutija i točaka puta, a povećajte vrijednost ako je reprodukcija videa iza njih. Ta vrijednost može biti negativna.",
+ "toast": {
+ "success": "Pomak anotacija za {{camera}} spremljen je u konfiguracijsku datoteku."
+ }
+ }
+ },
+ "carousel": {
+ "previous": "Prethodni slajd",
+ "next": "Sljedeći slajd"
+ }
+ },
+ "trackedObjectsCount_one": "{{count}} praćeni objekt ",
+ "trackedObjectsCount_few": "{{count}} praćena objekta ",
+ "trackedObjectsCount_other": "{{count}} praćenih objekata ",
+ "itemMenu": {
+ "downloadVideo": {
+ "label": "Preuzmi video",
+ "aria": "Preuzmi video"
+ },
+ "downloadSnapshot": {
+ "label": "Preuzmite snimku",
+ "aria": "Preuzmite snimku"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Preuzmite čistu snimku",
+ "aria": "Preuzmite čistu snimku"
+ },
+ "viewTrackingDetails": {
+ "label": "Pogledajte detalje praćenja",
+ "aria": "Prikaži detalje praćenja"
+ },
+ "findSimilar": {
+ "label": "Pronađi slične",
+ "aria": "Pronađi slične praćene objekte"
+ },
+ "addTrigger": {
+ "label": "Dodaj okidač",
+ "aria": "Dodajte okidač za ovaj praćeni objekt"
+ },
+ "audioTranscription": {
+ "label": "Prepisivanje",
+ "aria": "Zatražite audio transkripciju"
+ },
+ "submitToPlus": {
+ "label": "Pošalji na Frigate+",
+ "aria": "Pošalji na Frigate Plus"
+ },
+ "viewInHistory": {
+ "label": "Pogled u povijest",
+ "aria": "Pogled u povijest"
+ },
+ "deleteTrackedObject": {
+ "label": "Izbriši ovaj praćeni objekt"
+ },
+ "showObjectDetails": {
+ "label": "Prikaži putanju objekta"
+ },
+ "hideObjectDetails": {
+ "label": "Put skrivanja objekta"
+ }
+ },
+ "dialog": {
+ "confirmDelete": {
+ "title": "Potvrdi brisanje",
+ "desc": "Brisanjem ovog praćenog objekta uklanja se snimka, sve spremljene ugradnje i svi povezani unosi o praćenju. Snimljeni materijal ovog praćenog objekta u prikazu Povijesti NEĆE biti izbrisan.Kutije pokreta
Crvene kutije bit će preklopljene na dijelove okvira gdje se trenutno detektira gibanje
" + }, + "regions": { + "title": "Regije", + "desc": "Prikaži okvir regije od interesa poslan detektoru objekata", + "tips": "Kutije Regije
Svijetlozelene kutije bit će preklopljene na područja od interesa u okviru koja se šalju detektoru objekata.
" + }, + "paths": { + "title": "Putovi", + "desc": "Prikazati značajne točke putanje praćenog objekta", + "tips": "Putovi
Linije i krugovi označavaju značajne točke na koje se praćeni objekt pomaknuo tijekom svog životnog ciklusa.
" + }, + "objectShapeFilterDrawing": { + "title": "Crtanje filtera prema obliku objekta", + "desc": "Nacrtajte pravokutnik na slici kako biste vidjeli područje i detalje omjera", + "tips": "Omogućite ovu opciju za crtanje pravokutnika na slici kamere kako biste prikazali njegovu površinu i omjer. Te vrijednosti se zatim mogu koristiti za postavljanje parametara filtera oblika objekta u vašoj konfiguraciji.", + "score": "Ocjena", + "ratio": "Omjer", + "area": "Površina" + } + }, + "users": { + "title": "Korisnici", + "management": { + "title": "Upravljanje korisnicima", + "desc": "Upravljajte korisničkim računima ove Frigate instance." + }, + "addUser": "Dodaj korisnika", + "updatePassword": "Resetiraj lozinku", + "toast": { + "success": { + "createUser": "User {{user}} uspješno stvoren", + "deleteUser": "Korisnik {{user}} uspješno izbrisan", + "updatePassword": "Lozinka je uspješno ažurirana.", + "roleUpdated": "Uloga ažurirana za {{user}}" + }, + "error": { + "setPasswordFailed": "Neuspješno spremanje lozinke: {{errorMessage}}", + "createUserFailed": "Neuspješno stvaranje korisnika: {{errorMessage}}", + "deleteUserFailed": "Neuspješno brisanje korisnika: {{errorMessage}}", + "roleUpdateFailed": "Neuspješno ažuriranje uloge: {{errorMessage}}" + } + }, + "table": { + "username": "Korisničko ime", + "actions": "Radnje", + "role": "Uloga", + "noUsers": "Nema pronađenih korisnika.", + "changeRole": "Promijenite ulogu korisnika", + "password": "Resetiraj lozinku", + "deleteUser": "Izbriši korisnika" + }, + "dialog": { + "form": { + "user": { + "title": "Korisničko ime", + "desc": "Dozvoljeni su samo slova, brojevi, točkice i podcrtice.", + "placeholder": "Unesite korisničko ime" + }, + "password": { + "title": "Lozinka", + "placeholder": "Unesite lozinku", + "show": "Prikaži lozinku", + "hide": "Sakrij lozinku", + "confirm": { + "title": "Potvrdi lozinku", + "placeholder": "Potvrdi lozinku" + }, + "strength": { + "title": "Snaga lozinke: ", + "weak": "Slaba", + "medium": "Srednje jaka", + "strong": "Snažna", + "veryStrong": "Vrlo snažna" + }, + "requirements": { + "title": "Zahtjevi za lozinku:", + "length": "Najmanje 8 znakova", + "uppercase": "Barem jedno veliko slovo", + "digit": "Barem jedna znamenka", + "special": "Barem jedan poseban znak (!@#$%^&*(),.?\":{}|<>)" + }, + "match": "Lozinke se podudaraju", + "notMatch": "Lozinke se ne podudaraju" + }, + "newPassword": { + "title": "Nova lozinka", + "placeholder": "Unesite novu lozinku", + "confirm": { + "placeholder": "Ponovno unesite novu lozinku" + } + }, + "currentPassword": { + "title": "Trenutna lozinka", + "placeholder": "Unesite svoju trenutnu lozinku" + }, + "usernameIsRequired": "Potrebno je korisničko ime", + "passwordIsRequired": "Potrebna je lozinka" + }, + "createUser": { + "title": "Napravi novog korisnika", + "desc": "Dodajte novi korisnički račun i odredite ulogu za pristup područjima Frigate sučelja.", + "usernameOnlyInclude": "Korisničko ime može sadržavati samo slova, brojeve, . ili _", + "confirmPassword": "Molimo potvrdite svoju lozinku" + }, + "deleteUser": { + "title": "Izbriši korisnika", + "desc": "Ova radnja se ne može poništiti. To će trajno izbrisati korisnički račun i ukloniti sve povezane podatke.", + "warn": "Jeste li sigurni da želite izbrisati {{username}}?" + }, + "passwordSetting": { + "cannotBeEmpty": "Lozinka ne smije biti prazna", + "doNotMatch": "Lozinke se ne podudaraju", + "currentPasswordRequired": "Trenutna je lozinka potrebna", + "incorrectCurrentPassword": "Trenutna lozinka je netočna", + "passwordVerificationFailed": "Neuspješno potvrđivanje lozinke", + "updatePassword": "Ažuriraj lozinku za {{username}}", + "setPassword": "Postavi lozinku", + "desc": "Napravite jaku lozinku kako biste zaštitili ovaj račun.", + "multiDeviceWarning": "Svi ostali uređaji na kojima ste prijavljeni morat će se ponovno prijaviti unutar {{refresh_time}}.", + "multiDeviceAdmin": "Također možete prisiliti sve korisnike na trenutnu ponovnu autentifikaciju rotiranjem vaše JWT tajne." + }, + "changeRole": { + "title": "Promjena uloge korisnika", + "select": "Odaberite ulogu", + "desc": "Ažuriraj dopuštenja za {{username}}", + "roleInfo": { + "intro": "Odaberite odgovarajuću ulogu za ovog korisnika:", + "admin": "Admin", + "adminDesc": "Potpuni pristup svim značajkama.", + "viewer": "Gledatelj", + "viewerDesc": "Ograničeno samo na Nadzorne ploče uživo, Pregled, Istraži i Izvoz.", + "customDesc": "Prilagođena uloga s određenim pristupom kameri." + } + } + } + }, + "notification": { + "title": "Obavijesti", + "notificationSettings": { + "title": "Postavke obavijesti", + "desc": "Frigate može nativno slati push obavijesti na vaš uređaj kada je pokrenut u pregledniku ili instaliran kao PWA." + }, + "notificationUnavailable": { + "title": "Obavijesti nisu dostupne", + "desc": "Web push obavijesti zahtijevaju siguran kontekst (https://...). Ovo je ograničenje preglednika. Pristupite Frigateu sigurno kako biste koristili obavijesti."
+ },
+ "globalSettings": {
+ "title": "Globalna okruženja",
+ "desc": "Privremeno obustavite obavijesti za određene kamere na svim registriranim uređajima."
+ },
+ "email": {
+ "title": "E-pošta",
+ "placeholder": "npr. example@email.com",
+ "desc": "Potreban je valjani e-mail i koristit će se da vas obavijesti ako dođe do problema s push uslugom."
+ },
+ "cameras": {
+ "title": "Kamere",
+ "noCameras": "Nema dostupnih kamera",
+ "desc": "Odaberite za koje kamere ćete uključiti obavijesti."
+ },
+ "deviceSpecific": "Postavke specifične za uređaj",
+ "registerDevice": "Registrirajte ovaj uređaj",
+ "unregisterDevice": "Odjavite ovaj uređaj",
+ "sendTestNotification": "Pošaljite obavijest o testu",
+ "unsavedRegistrations": "Registracije nespremljenih obavijesti",
+ "unsavedChanges": "Promjene nespremljenih obavijesti",
+ "active": "Obavijesti su aktivne",
+ "suspended": "Obavijesti obustavljene {{time}}",
+ "suspendTime": {
+ "suspend": "Obustava",
+ "5minutes": "Pauziraj na 5 minuta",
+ "10minutes": "Pauziraj na 10 minuta",
+ "30minutes": "Pauziraj na 30 minuta",
+ "1hour": "Pauziraj na 1 sat",
+ "12hours": "Pauziraj na 12 sati",
+ "24hours": "Pauziraj na 24 sata",
+ "untilRestart": "Pauziraj do ponovnog pokretanja"
+ },
+ "cancelSuspension": "Otkaži pauziranje obavijesti",
+ "toast": {
+ "success": {
+ "registered": "Uspješno registriran za obavijesti. Ponovno pokretanje Frigate-a je potrebno prije nego što se mogu poslati bilo kakve obavijesti (uključujući testnu obavijest).",
+ "settingSaved": "Postavke obavijesti su spremljene."
+ },
+ "error": {
+ "registerFailed": "Neuspješno spremanje registracije obavijesti."
+ }
+ }
+ },
+ "frigatePlus": {
+ "title": "Frigate+ postavke",
+ "apiKey": {
+ "title": "Frigate+ API ključ",
+ "validated": "Frigate+ API ključ je detektiran i validiran",
+ "notValidated": "Frigate+ API ključ nije detektiran ili nije validiran",
+ "desc": "Frigate+ API ključ omogućuje integraciju s Frigate+ uslugom.",
+ "plusLink": "Pročitajte više o Frigate+"
+ },
+ "snapshotConfig": {
+ "title": "Konfiguracija snimaka",
+ "desc": "Slanje na Frigate+ zahtijeva da su u tvojoj konfiguraciji omogućeni i snapshotovi i clean_copy snapshotovi.",
+ "cleanCopyWarning": "Neke kamere imaju omogućene snimke, ali je čista kopija onemogućena. Morate omogućiti clean_copy u konfiguraciji za snimke da biste mogli slati slike s tih kamera na Frigate+.",
+ "table": {
+ "camera": "Kamera",
+ "snapshots": "Snimke",
+ "cleanCopySnapshots": "clean_copy Snimke"
+ }
+ },
+ "modelInfo": {
+ "title": "Informacije o modelu",
+ "modelType": "Tip modela",
+ "trainDate": "Datum treniranja",
+ "baseModel": "Osnovni model",
+ "plusModelType": {
+ "baseModel": "Osnovni model",
+ "userModel": "Fino podešen"
+ },
+ "supportedDetectors": "Podržani detektori",
+ "cameras": "Kamere",
+ "loading": "Učitavanje informacija o modelu…",
+ "error": "Neuspješno učitavanje informacije o modelu",
+ "availableModels": "Dostupni modeli",
+ "loadingAvailableModels": "Učitavanje dostupnih modela…",
+ "modelSelect": "Dostupne modele na Frigate+ možete odabrati ovdje. Imajte na umu da se mogu odabrati samo modeli kompatibilni s vašom trenutnom konfiguracijom detektora."
+ },
+ "unsavedChanges": "Nespremljene promjene postavki Frigate+",
+ "restart_required": "Potreban je restart (promijenjen model Frigate+)",
+ "toast": {
+ "success": "Frigate+ postavke su spremljene. Ponovno pokrenite Frigate da primijenite promjene.",
+ "error": "Nije uspjelo spremiti promjene konfiguracije: {{errorMessage}}"
+ }
+ },
+ "triggers": {
+ "documentTitle": "Okidači",
+ "semanticSearch": {
+ "title": "Semantičko pretraživanje je onemogućeno",
+ "desc": "Semantičko pretraživanje mora biti omogućeno za korištenje okidača."
+ },
+ "management": {
+ "title": "Okidači",
+ "desc": "Upravljanje okidačima za {{camera}}. Koristite tip sličice za okidanje na sličnim sličicama kao odabrani praćeni objekt, a tip opisa za okidanje na sličnim opisima teksta koji ste odredili."
+ },
+ "addTrigger": "Dodaj okidač",
+ "table": {
+ "name": "Ime",
+ "type": "Tip",
+ "content": "Sadržaj",
+ "threshold": "Prag",
+ "actions": "Radnje",
+ "noTriggers": "Nema konfiguriranih okidača za ovu kameru.",
+ "edit": "Uređivanje",
+ "deleteTrigger": "Okidač za brisanje",
+ "lastTriggered": "Zadnji put okinut"
+ },
+ "type": {
+ "thumbnail": "Sličica",
+ "description": "Opis"
+ },
+ "actions": {
+ "notification": "Pošalji obavijest",
+ "sub_label": "Dodaj podoznaku",
+ "attribute": "Dodaj atribut"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "Kreiraj okidač",
+ "desc": "Kreirajte okidač za kameru {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Uredi okidač",
+ "desc": "Uredi postavke za okidač na kameri {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Obriši okidač",
+ "desc": "Jeste li sigurni da želite izbrisati okidač {{triggerName}}? Ova radnja se ne može poništiti."
+ },
+ "form": {
+ "name": {
+ "title": "Ime",
+ "placeholder": "Unesite ime okidača",
+ "description": "Unesite jedinstveno ime ili opis kako biste identificirali ovaj okidač",
+ "error": {
+ "minLength": "Polje mora imati najmanje 2 znaka.",
+ "invalidCharacters": "Polje može sadržavati samo slova, brojeve, podcrte i crtice.",
+ "alreadyExists": "Okidač s ovim imenom već postoji za ovu kameru."
+ }
+ },
+ "enabled": {
+ "description": "Omogućite ili onemogućite ovaj okidač"
+ },
+ "type": {
+ "title": "Tip",
+ "placeholder": "Odaberite tip okidača",
+ "description": "Okini kada se detektira sličan opis praćenog objekta",
+ "thumbnail": "Okini kada se detektira sličan sličica praćenog objekta"
+ },
+ "content": {
+ "title": "Sadržaj",
+ "imagePlaceholder": "Odaberi sličicu",
+ "textPlaceholder": "Unesi tekstualni sadržaj",
+ "imageDesc": "Prikazuje se samo najnovijih 100 sličica. Ako ne možete pronaći željenu sličicu, molimo pregledajte ranije objekte u Explore i postavite okidač iz izbornika tamo.",
+ "textDesc": "Unesite tekst kako biste okinuli ovu radnju kada se detektira sličan opis praćenog objekta.",
+ "error": {
+ "required": "Sadržaj je obavezan."
+ }
+ },
+ "threshold": {
+ "title": "Prag",
+ "desc": "Postavite prag sličnosti za ovaj okidač. Viši prag znači da je potrebno bliže podudaranje da bi se okidač aktivirao.",
+ "error": {
+ "min": "Prag mora biti najmanje 0",
+ "max": "Prag mora biti najviše 1"
+ }
+ },
+ "actions": {
+ "title": "Radnje",
+ "desc": "Prema zadanim postavkama, Frigate šalje MQTT poruku za sve okidače. Podoznake dodaju ime okidača na oznaku objekta, a atributi su pretraživi metapodaci pohranjeni zasebno u metapodacima praćenih objekata.",
+ "error": {
+ "min": "Mora se odabrati barem jedna radnja."
+ }
+ }
+ }
+ },
+ "wizard": {
+ "title": "Stvori okidač",
+ "step1": {
+ "description": "Konfigurirajte osnovne postavke za svoj okidač."
+ },
+ "step2": {
+ "description": "Postavite sadržaj koji će okinuti ovu radnju."
+ },
+ "step3": {
+ "description": "Konfigurirajte prag i akcije za ovaj okidač."
+ },
+ "steps": {
+ "nameAndType": "Naziv i tip",
+ "configureData": "Konfiguriraj podatke",
+ "thresholdAndActions": "Prag i akcije"
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Okidač {{name}} uspješno stvoren.",
+ "updateTrigger": "Okidač {{name}} je uspješno ažuriran.",
+ "deleteTrigger": "Okidač {{name}} uspješno izbrisan."
+ },
+ "error": {
+ "createTriggerFailed": "Neuspješno stvaranje okidača: {{errorMessage}}",
+ "updateTriggerFailed": "Neuspješno ažuriranje okidača: {{errorMessage}}",
+ "deleteTriggerFailed": "Neuspješno brisanje okidača: {{errorMessage}}"
+ }
+ }
+ }
+}
diff --git a/web/public/locales/hr/views/system.json b/web/public/locales/hr/views/system.json
new file mode 100644
index 000000000..880eca7d2
--- /dev/null
+++ b/web/public/locales/hr/views/system.json
@@ -0,0 +1,208 @@
+{
+ "documentTitle": {
+ "cameras": "Statistika Kamera - Frigate",
+ "general": "Opća Statistika - Frigate",
+ "logs": {
+ "go2rtc": "Zapisnici Go2RTC - Frigate",
+ "nginx": "Zapisnici Nginx - Frigate",
+ "frigate": "Zapisnici Frigate - Frigate"
+ },
+ "storage": "Statistika Pohrane - Frigate",
+ "enrichments": "Statistika Obogaćenja - Frigate"
+ },
+ "title": "Sustav",
+ "logs": {
+ "download": {
+ "label": "Preuzmi Zapisnike"
+ },
+ "type": {
+ "label": "Tip",
+ "timestamp": "Vremenska oznaka",
+ "tag": "Oznaka",
+ "message": "Poruka"
+ },
+ "copy": {
+ "label": "Kopiraj u međuspremnik",
+ "success": "Zapisnici kopirani u međuspremnik",
+ "error": "Nije moguće kopirati zapisnike u međuspremnik"
+ },
+ "tips": "Zapisnici se prenose sa servera",
+ "toast": {
+ "error": {
+ "fetchingLogsFailed": "Greška pri dohvaćanju zapisnika: {{errorMessage}}",
+ "whileStreamingLogs": "Greška tijekom prijenosa zapisnika: {{errorMessage}}"
+ }
+ }
+ },
+ "metrics": "Metrike sustava",
+ "general": {
+ "title": "Općenito",
+ "detector": {
+ "title": "Detektori",
+ "inferenceSpeed": "Brzina inferencije detektora",
+ "temperature": "Temperatura detektora",
+ "cpuUsage": "Upotreba CPU-a detektora",
+ "cpuUsageInformation": "CPU korišten za pripremu ulaznih i izlaznih podataka za/od modela detekcije. Ova vrijednost ne mjeri korištenje za inferenciju, čak ni ako se koristi GPU ili akcelerator.",
+ "memoryUsage": "Upotreba memorije detektora"
+ },
+ "hardwareInfo": {
+ "title": "Informacije o hardveru",
+ "gpuUsage": "Upotreba GPU-a",
+ "gpuMemory": "Memorija GPU-a",
+ "gpuEncoder": "GPU Encoder",
+ "gpuDecoder": "GPU Decoder",
+ "gpuInfo": {
+ "vainfoOutput": {
+ "title": "Vainfo Izlaz",
+ "returnCode": "Povratni kod: {{code}}",
+ "processOutput": "Izlaz procesa:",
+ "processError": "Greška procesa:"
+ },
+ "nvidiaSMIOutput": {
+ "title": "Nvidia SMI Izlaz",
+ "name": "Naziv: {{name}}",
+ "driver": "Driver: {{driver}}",
+ "cudaComputerCapability": "CUDA Compute Capability: {{cuda_compute}}",
+ "vbios": "VBios Informacije: {{vbios}}"
+ },
+ "closeInfo": {
+ "label": "Zatvori informacije o GPU-u"
+ },
+ "copyInfo": {
+ "label": "Kopiraj informacije o GPU-u"
+ },
+ "toast": {
+ "success": "Informacije o GPU-u kopirane u međuspremnik"
+ }
+ },
+ "npuUsage": "Upotreba NPU-a",
+ "npuMemory": "Memorija NPU-a",
+ "intelGpuWarning": {
+ "title": "Upozorenje Intel GPU Statistika",
+ "message": "Statistika GPU-a nije dostupna",
+ "description": "Ovo je poznata greška u Intelovim alatima za izvještavanje GPU statistike (intel_gpu_top) gdje će se podaci prekinuti i stalno prikazivati 0% korištenja GPU-a, čak i kada hardversko ubrzanje i detekcija objekata pravilno rade na (i)GPU-u. Ovo nije greška Frigate-a. Možete ponovno pokrenuti host da privremeno riješite problem i potvrdite da GPU radi ispravno. Ovo ne utječe na performanse."
+ }
+ },
+ "otherProcesses": {
+ "title": "Ostali Procesi",
+ "processCpuUsage": "Upotreba CPU-a procesa",
+ "processMemoryUsage": "Upotreba memorije procesa",
+ "series": {
+ "go2rtc": "go2rtc",
+ "recording": "snimanje",
+ "review_segment": "pregled segmenta",
+ "embeddings": "ugrađivanja",
+ "audio_detector": "audio detektor"
+ }
+ }
+ },
+ "storage": {
+ "title": "Pohrana",
+ "overview": "Pregled",
+ "recordings": {
+ "title": "Snimke",
+ "tips": "Ova vrijednost predstavlja ukupno korištenje prostora za snimke u Frigate bazi podataka. Frigate ne prati korištenje prostora za sve datoteke na disku.",
+ "earliestRecording": "Najranija dostupna snimka:"
+ },
+ "shm": {
+ "title": "SHM (zajednička memorija) alokacija",
+ "warning": "Trenutna veličina SHM od {{total}} MB je premala. Povećajte je na najmanje {{min_shm}} MB."
+ },
+ "cameraStorage": {
+ "title": "Pohrana Kamere",
+ "camera": "Kamera",
+ "unusedStorageInformation": "Informacije o neiskorištenom prostoru",
+ "storageUsed": "Pohrana",
+ "percentageOfTotalUsed": "Postotak od ukupnog",
+ "bandwidth": "Propusnost",
+ "unused": {
+ "title": "Neiskorišteno",
+ "tips": "Ova vrijednost možda ne prikazuje točno slobodan prostor dostupan Frigate-u ako imate druge datoteke pohranjene na disku osim Frigate snimaka. Frigate ne prati korištenje prostora izvan svojih snimki."
+ }
+ }
+ },
+ "cameras": {
+ "title": "Kamere",
+ "overview": "Pregled",
+ "info": {
+ "aspectRatio": "Omjer stranica",
+ "cameraProbeInfo": "{{camera}} Informacije ispitane od kamere",
+ "streamDataFromFFPROBE": "Podaci emitiranja dohvaćeni su pomoću ffprobe.",
+ "fetching": "Dohvaćanje podataka kamere",
+ "stream": "Emitiranje {{idx}}",
+ "video": "Video:",
+ "codec": "Kodek:",
+ "resolution": "Rezolucija:",
+ "fps": "FPS:",
+ "unknown": "Nepoznato",
+ "audio": "Audio:",
+ "error": "Greška: {{error}}",
+ "tips": {
+ "title": "Informacije Ispitivanja Kamere"
+ }
+ },
+ "framesAndDetections": "Okviri / Detekcije",
+ "label": {
+ "camera": "kamera",
+ "detect": "detekcija",
+ "skipped": "preskočeno",
+ "ffmpeg": "FFmpeg",
+ "capture": "snimanje",
+ "overallFramesPerSecond": "ukupni okviri po sekundi",
+ "overallDetectionsPerSecond": "ukupne detekcije po sekundi",
+ "overallSkippedDetectionsPerSecond": "ukupne preskočene detekcije po sekundi",
+ "cameraFfmpeg": "{{camName}} FFmpeg",
+ "cameraCapture": "{{camName}} snimanje",
+ "cameraDetect": "{{camName}} detekcija",
+ "cameraFramesPerSecond": "{{camName}} okviri po sekundi",
+ "cameraDetectionsPerSecond": "{{camName}} detekcije po sekundi",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} preskočene detekcije po sekundi"
+ },
+ "toast": {
+ "success": {
+ "copyToClipboard": "Podaci probe kopirani u međuspremnik."
+ },
+ "error": {
+ "unableToProbeCamera": "Nije moguće probati kameru: {{errorMessage}}"
+ }
+ }
+ },
+ "lastRefreshed": "Zadnje osvježavanje: ",
+ "stats": {
+ "ffmpegHighCpuUsage": "{{camera}} ima visoku upotrebu CPU-a za FFmpeg ({{ffmpegAvg}}%)",
+ "detectHighCpuUsage": "{{camera}} ima visoku upotrebu CPU-a za detekciju ({{detectAvg}}%)",
+ "healthy": "Sustav je zdrav",
+ "reindexingEmbeddings": "Reindeksiranje embeddings ({{processed}}% završeno)",
+ "cameraIsOffline": "{{camera}} je offline",
+ "detectIsSlow": "{{detect}} je sporo ({{speed}} ms)",
+ "detectIsVerySlow": "{{detect}} je vrlo sporo ({{speed}} ms)",
+ "shmTooLow": "/dev/shm alokacija ({{total}} MB) treba biti povećana na najmanje {{min}} MB."
+ },
+ "enrichments": {
+ "title": "Obogaćenja",
+ "infPerSecond": "Inferencija po sekundi",
+ "averageInf": "Prosječno vrijeme inferencije",
+ "embeddings": {
+ "image_embedding": "Ugrađivanja slike",
+ "text_embedding": "Ugrađivanja teksta",
+ "face_recognition": "Prepoznavanje lica",
+ "plate_recognition": "Prepoznavanje registarskih pločica",
+ "image_embedding_speed": "Brzina Image Embedding",
+ "face_embedding_speed": "Brzina Face Embedding",
+ "face_recognition_speed": "Brzina prepoznavanja lica",
+ "plate_recognition_speed": "Brzina prepoznavanja registarskih pločica",
+ "text_embedding_speed": "Brzina Text Embedding",
+ "yolov9_plate_detection_speed": "Brzina YOLOv9 prepoznavanja pločica",
+ "yolov9_plate_detection": "YOLOv9 Prepoznavanje pločica",
+ "review_description": "Opis Pregleda",
+ "review_description_speed": "Brzina Opisa Pregleda",
+ "review_description_events_per_second": "Opis Pregleda",
+ "object_description": "Opis Objekta",
+ "object_description_speed": "Brzina Opisa Objekta",
+ "object_description_events_per_second": "Opis Objekta",
+ "classification": "{{name}} Klasifikacija",
+ "classification_speed": "Brzina {{name}} Klasifikacije",
+ "classification_events_per_second": "{{name}} Klasifikacija po događajima po sekundi"
+ }
+ }
+}
diff --git a/web/public/locales/hu/audio.json b/web/public/locales/hu/audio.json
index 7d5d49bf9..7f31e0459 100644
--- a/web/public/locales/hu/audio.json
+++ b/web/public/locales/hu/audio.json
@@ -149,7 +149,7 @@
"car": "Autó",
"bus": "Busz",
"motorcycle": "Motor",
- "train": "Vonat",
+ "train": "Betanít",
"bicycle": "Bicikli",
"scream": "Sikoly",
"throat_clearing": "Torokköszörülés",
@@ -425,5 +425,6 @@
"crack": "Törés",
"chink": "Csörömpölés",
"shatter": "Összetörés",
- "field_recording": "Helyszíni felvétel"
+ "field_recording": "Helyszíni felvétel",
+ "noise": "Zaj"
}
diff --git a/web/public/locales/hu/common.json b/web/public/locales/hu/common.json
index c45157b38..42a9df69a 100644
--- a/web/public/locales/hu/common.json
+++ b/web/public/locales/hu/common.json
@@ -72,7 +72,10 @@
"24hour": "MMM d, HH:mm",
"12hour": "MMM d, h:mm aaa"
},
- "formattedTimestampMonthDay": "MMM d"
+ "formattedTimestampMonthDay": "MMM d",
+ "inProgress": "Folyamatban",
+ "invalidStartTime": "Érvénytelen kezdeti idő",
+ "never": "Soha"
},
"menu": {
"darkMode": {
@@ -142,7 +145,15 @@
"ro": "Román",
"hu": "Magyar",
"fi": "Finn",
- "th": "Thai"
+ "th": "Thai",
+ "ptBR": "Português brasileiro (Brazil portugál)",
+ "sr": "Српски (Szerb)",
+ "sl": "Slovenščina (Szlovén)",
+ "lt": "Lietuvių (Litván)",
+ "bg": "Български (Bolgár)",
+ "gl": "Galego (Galíciai)",
+ "id": "Bahasa Indonesia (Indonéz)",
+ "ur": "اردو (Urdu)"
},
"uiPlayground": "UI játszótér",
"faceLibrary": "Arc Könyvtár",
@@ -168,7 +179,7 @@
},
"role": {
"viewer": "Néző",
- "title": "Szerep",
+ "title": "Szerepkör",
"admin": "Adminisztrátor",
"desc": "Az adminisztrátoroknak teljes hozzáférése van az összes feature-höz. A nézők csak a kamerákat láthatják, áttekinthetik az elemeket és az előzményeket a UI-on."
},
@@ -213,6 +224,14 @@
"length": {
"feet": "láb",
"meters": "méter"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/óra",
+ "mbph": "MB/óra",
+ "gbph": "GB/óra"
}
},
"button": {
@@ -253,6 +272,11 @@
"next": "Következő"
},
"label": {
- "back": "Vissza"
+ "back": "Vissza",
+ "all": "Mind"
+ },
+ "readTheDocumentation": "Olvassa el a dokumentációt",
+ "information": {
+ "pixels": "{{area}}px"
}
}
diff --git a/web/public/locales/hu/components/auth.json b/web/public/locales/hu/components/auth.json
index 37dc3a2e4..43b8e9e17 100644
--- a/web/public/locales/hu/components/auth.json
+++ b/web/public/locales/hu/components/auth.json
@@ -10,6 +10,7 @@
"unknownError": "Ismeretlen hiba. Ellenőrizze a naplókat.",
"webUnknownError": "Ismeretlen hiba. Ellenőrizze a konzol naplókat.",
"rateLimit": "Túl sokszor próbálkozott. Próbálja meg később."
- }
+ },
+ "firstTimeLogin": "Először próbálsz bejelentkezni? A hitelesítési adatok a Frigate naplóiban vannak feltüntetve."
}
}
diff --git a/web/public/locales/hu/components/camera.json b/web/public/locales/hu/components/camera.json
index e53fb9c18..c5294818d 100644
--- a/web/public/locales/hu/components/camera.json
+++ b/web/public/locales/hu/components/camera.json
@@ -1,6 +1,6 @@
{
"group": {
- "label": "Kamera Csoport",
+ "label": "Kamera Csoportok",
"delete": {
"confirm": {
"desc": "Biztosan törölni akarja a következő kamera csoportot {{name}}?",
@@ -66,7 +66,8 @@
"desc": "Csak akkor engedélyezze ezt az opciót, ha a kamera élő közvetítése képhibás, és a kép jobb oldalán átlós vonal látható."
},
"desc": "Változtassa meg az élő adás beállításait ezen kamera csoport kijelzőjén. Ezek a beállítások eszköz/böngésző-specifikusak."
- }
+ },
+ "birdseye": "Madártávlat"
}
},
"debug": {
diff --git a/web/public/locales/hu/components/dialog.json b/web/public/locales/hu/components/dialog.json
index bff6ade19..c45eac1fc 100644
--- a/web/public/locales/hu/components/dialog.json
+++ b/web/public/locales/hu/components/dialog.json
@@ -1,10 +1,10 @@
{
"restart": {
- "title": "Biztosan újra szeretnéd indítani a Frigate-ot?",
+ "title": "Biztosan újra szeretnéd indítani a Frigate-et?",
"button": "Újraindítás",
"restarting": {
"title": "A Frigate újraindul",
- "content": "Az oldal újrtölt {{countdown}} másodperc múlva.",
+ "content": "Az oldal újratölt {{countdown}} másodperc múlva.",
"button": "Erőltetett újraindítás azonnal"
}
},
@@ -22,7 +22,7 @@
"ask_a": "Ez a tárgy egy {{label}}?",
"label": "Erősítse meg ezt a cimkét a Frigate plus felé",
"ask_an": "Ez a tárgy egy {{label}}?",
- "ask_full": "Ez a tárgy egy {{untranslatedLabel}} ({{translatedLabel}})?"
+ "ask_full": "Ez a tárgy egy {{translatedLabel}} ({{untranslatedLabel}})?"
}
}
},
@@ -107,7 +107,15 @@
"button": {
"markAsReviewed": "Megjelölés áttekintettként",
"deleteNow": "Törlés Most",
- "export": "Exportálás"
+ "export": "Exportálás",
+ "markAsUnreviewed": "Megjelölés nem ellenőrzöttként"
}
+ },
+ "imagePicker": {
+ "selectImage": "Válassza ki egy követett tárgy képét",
+ "search": {
+ "placeholder": "Keresés cimke vagy alcimke alapján..."
+ },
+ "noImages": "Nem találhatók bélyegképek ehhez a kamerához"
}
}
diff --git a/web/public/locales/hu/components/filter.json b/web/public/locales/hu/components/filter.json
index f4b9b9f39..3ec9ee2da 100644
--- a/web/public/locales/hu/components/filter.json
+++ b/web/public/locales/hu/components/filter.json
@@ -97,7 +97,7 @@
"label": "Keresés Forrás",
"options": {
"description": "Leírás",
- "thumbnailImage": "Bélyegkép"
+ "thumbnailImage": "Indexkép"
},
"desc": "Válassza ki, hogy a követett objektumok bélyegképeiben vagy leírásaiban szeretne keresni."
},
@@ -121,6 +121,20 @@
"noLicensePlatesFound": "Rendszámtábla nem található.",
"selectPlatesFromList": "Válasszon ki egy vagy több rendszámtáblát a listából.",
"loading": "Felismert rendszámtáblák betöltése…",
- "placeholder": "Kezdjen gépelni a rendszámok közötti kereséshez…"
+ "placeholder": "Kezdjen gépelni a rendszámok közötti kereséshez…",
+ "selectAll": "Mindet kijelöl",
+ "clearAll": "Mindet törli"
+ },
+ "classes": {
+ "label": "Osztályok",
+ "all": {
+ "title": "Minden Osztály"
+ },
+ "count_one": "{{count}} Osztály",
+ "count_other": "{{count}} Osztályok"
+ },
+ "attributes": {
+ "label": "Osztályozási attribútumok",
+ "all": "Minden attribútum"
}
}
diff --git a/web/public/locales/hu/objects.json b/web/public/locales/hu/objects.json
index 5bac94fc3..4b53d161b 100644
--- a/web/public/locales/hu/objects.json
+++ b/web/public/locales/hu/objects.json
@@ -5,7 +5,7 @@
"motorcycle": "Motor",
"airplane": "Repülőgép",
"bus": "Busz",
- "train": "Vonat",
+ "train": "Betanít",
"boat": "Hajó",
"dog": "Kutya",
"cat": "Macska",
diff --git a/web/public/locales/hu/views/classificationModel.json b/web/public/locales/hu/views/classificationModel.json
new file mode 100644
index 000000000..be35c7a4b
--- /dev/null
+++ b/web/public/locales/hu/views/classificationModel.json
@@ -0,0 +1,58 @@
+{
+ "documentTitle": "Osztályozási modellek - Frigate",
+ "button": {
+ "deleteClassificationAttempts": "Osztályozási képek törlése",
+ "deleteImages": "Képek törlése",
+ "trainModel": "Modell betanítása",
+ "deleteModels": "Modellek törlése",
+ "editModel": "Modell szerkesztése",
+ "renameCategory": "Osztály átnevezése",
+ "deleteCategory": "Osztály törlése",
+ "addClassification": "Osztályozás hozzáadása"
+ },
+ "toast": {
+ "success": {
+ "deletedImage": "Törölt képek",
+ "deletedModel_one": "Sikeresen törölt {{count}} modellt",
+ "deletedModel_other": "",
+ "categorizedImage": "A kép sikeresen osztályozva",
+ "deletedCategory": "Osztály törlése",
+ "trainedModel": "Sikeresen betanított modell.",
+ "trainingModel": "A modell tanítás sikeresen megkezdődött.",
+ "updatedModel": "Modellkonfiguráció sikeresen frissítve",
+ "renamedCategory": "Sikeresen átneveztük az osztályt {{name}} névre"
+ },
+ "error": {
+ "deleteImageFailed": "Törlés sikertelen: {{errorMessage}}",
+ "deleteCategoryFailed": "Nem sikerült törölni az osztályt: {{errorMessage}}"
+ }
+ },
+ "details": {
+ "none": "Nincs",
+ "unknown": "Ismeretlen",
+ "scoreInfo": "A pontszám az objektum összes észlelésében mért átlagos osztályozási megbízhatóságot jelöli."
+ },
+ "edit": {
+ "title": "Osztályozási modell szerkesztése"
+ },
+ "wizard": {
+ "step1": {
+ "name": "Név"
+ },
+ "step2": {
+ "cameras": "Kamerák"
+ }
+ },
+ "tooltip": {
+ "trainingInProgress": "A modell betanítás alatt van",
+ "noNewImages": "Nincsenek új képek a betanításhoz. Először osztályozzon több képet az adathalmazban.",
+ "noChanges": "Az adathalmazban nem történt változás az utolsó betanítás óta.",
+ "modelNotReady": "A modell nem áll készen a betanításra"
+ },
+ "menu": {
+ "objects": "Objektumok"
+ },
+ "train": {
+ "titleShort": "Friss"
+ }
+}
diff --git a/web/public/locales/hu/views/configEditor.json b/web/public/locales/hu/views/configEditor.json
index b921c987d..69fa822e9 100644
--- a/web/public/locales/hu/views/configEditor.json
+++ b/web/public/locales/hu/views/configEditor.json
@@ -12,5 +12,7 @@
"savingError": "Hiba a konfiguráció mentésekor"
}
},
- "confirm": "Kilép mentés nélkül?"
+ "confirm": "Kilép mentés nélkül?",
+ "safeConfigEditor": "Konfiguráció szerkesztő (Biztosnági Mód)",
+ "safeModeDescription": "Frigate biztonsági módban van konfigurációs hiba miatt."
}
diff --git a/web/public/locales/hu/views/events.json b/web/public/locales/hu/views/events.json
index 586953de1..123e32cc3 100644
--- a/web/public/locales/hu/views/events.json
+++ b/web/public/locales/hu/views/events.json
@@ -3,7 +3,11 @@
"empty": {
"detection": "Nincs megnézendő észlelés",
"alert": "Nincs megnézendő riasztás",
- "motion": "Nem található mozgás"
+ "motion": "Nem található mozgás",
+ "recordingsDisabled": {
+ "title": "A felvétel készítést engedélyezni kell",
+ "description": "Csak akkor hozhatók létre áttekintési elemek egy kamerához, ha az adott kamerához engedélyezve vannak a felvételek."
+ }
},
"detections": "Észlelések",
"motion": {
@@ -34,5 +38,21 @@
"markTheseItemsAsReviewed": "Ezen elemek megjelölése áttekintettként",
"markAsReviewed": "Megjelölés Áttekintettként",
"selected_one": "{{count}} kiválasztva",
- "selected_other": "{{count}} kiválasztva"
+ "selected_other": "{{count}} kiválasztva",
+ "suspiciousActivity": "Gyanús Tevékenység",
+ "threateningActivity": "Fenyegető Tevékenység",
+ "zoomIn": "Nagyítás",
+ "zoomOut": "Kicsinyítés",
+ "detail": {
+ "trackedObject_other": "{{count}} objektum",
+ "label": "Részletes",
+ "noDataFound": "Nincsenek részletes adatok áttekintésre",
+ "aria": "Részletes nézet kapcsolása",
+ "trackedObject_one": "{{count}} objektum",
+ "noObjectDetailData": "Nincsenek elérhető objektumrészlet adatok.",
+ "settings": "Részletes nézet beállításai",
+ "alwaysExpandActive": {
+ "title": "Mindig kibontja az aktív részt"
+ }
+ }
}
diff --git a/web/public/locales/hu/views/explore.json b/web/public/locales/hu/views/explore.json
index 9f5cd4814..e01a1661b 100644
--- a/web/public/locales/hu/views/explore.json
+++ b/web/public/locales/hu/views/explore.json
@@ -27,6 +27,14 @@
"downloadSnapshot": {
"aria": "Pillanatfelvétel letöltése",
"label": "Pillanatfelvétel letöltése"
+ },
+ "addTrigger": {
+ "label": "Indító hozzáadása",
+ "aria": "Indító hozzáadása ehhez a követett tárgyhoz"
+ },
+ "audioTranscription": {
+ "label": "Átírás",
+ "aria": "Hangátirat kérése"
}
},
"details": {
@@ -65,12 +73,14 @@
"error": {
"updatedLPRFailed": "Rendszám frissítése sikertelen: {{errorMessage}}",
"updatedSublabelFailed": "Alcimke frissítése sikertelen: {{errorMessage}}",
- "regenerate": "Nem sikerült meghívni a(z) {{provider}} szolgáltatót az új leírásért: {{errorMessage}}"
+ "regenerate": "Nem sikerült meghívni a(z) {{provider}} szolgáltatót az új leírásért: {{errorMessage}}",
+ "audioTranscription": "Nem sikerült hangátiratot kérni: {{errorMessage}}"
},
"success": {
"updatedSublabel": "Az alcimke sikeresen frissítve.",
"updatedLPR": "Rendszám sikeresen frissítve.",
- "regenerate": "Új leírást kértünk a(z) {{provider}} szolgáltatótól. A szolgáltató sebességétől függően az új leírás előállítása eltarthat egy ideig."
+ "regenerate": "Új leírást kértünk a(z) {{provider}} szolgáltatótól. A szolgáltató sebességétől függően az új leírás előállítása eltarthat egy ideig.",
+ "audioTranscription": "Sikeresen kérte a hangátírást."
}
},
"button": {
@@ -97,7 +107,10 @@
},
"findSimilar": "Keress Hasonlót"
},
- "expandRegenerationMenu": "Újragenerálási menü kiterjesztése"
+ "expandRegenerationMenu": "Újragenerálási menü kiterjesztése",
+ "score": {
+ "label": "Pontszám"
+ }
},
"searchResult": {
"deleteTrackedObject": {
@@ -200,8 +213,32 @@
"video": "videó",
"object_lifecycle": "tárgy életciklus",
"details": "részletek",
- "snapshot": "pillanatfelvétel"
+ "snapshot": "pillanatfelvétel",
+ "thumbnail": "bélyegkép",
+ "tracking_details": "követési adatok"
},
"trackedObjectDetails": "Követett Tárgy Részletei",
- "exploreMore": "Fedezzen fel több {{label}} tárgyat"
+ "exploreMore": "Fedezzen fel több {{label}} tárgyat",
+ "aiAnalysis": {
+ "title": "MI-elemzés"
+ },
+ "concerns": {
+ "label": "Aggodalmak"
+ },
+ "trackingDetails": {
+ "lifecycleItemDesc": {
+ "active": "{{label}} aktív lett",
+ "attribute": {
+ "other": "{{label}} felismerve mint {{attribute}}"
+ },
+ "external": "{{label}} érzékelve",
+ "header": {
+ "zones": "Zónák",
+ "ratio": "Arány",
+ "area": "Terület"
+ }
+ },
+ "title": "Követési adatok",
+ "noImageFound": "Nem található kép ehhez az időbélyeghez."
+ }
}
diff --git a/web/public/locales/hu/views/exports.json b/web/public/locales/hu/views/exports.json
index f54c70923..ab07aba94 100644
--- a/web/public/locales/hu/views/exports.json
+++ b/web/public/locales/hu/views/exports.json
@@ -13,5 +13,11 @@
"error": {
"renameExportFailed": "Sikertelen export átnevezés: {{errorMessage}}"
}
+ },
+ "tooltip": {
+ "downloadVideo": "Videó letöltése",
+ "editName": "Név szerkesztése",
+ "deleteExport": "Export törlése",
+ "shareExport": "Export megosztása"
}
}
diff --git a/web/public/locales/hu/views/faceLibrary.json b/web/public/locales/hu/views/faceLibrary.json
index 4aaef392d..788b0caea 100644
--- a/web/public/locales/hu/views/faceLibrary.json
+++ b/web/public/locales/hu/views/faceLibrary.json
@@ -1,7 +1,7 @@
{
"renameFace": {
"title": "Arc átnevezése",
- "desc": "Adjon meg egy új nevet {{name}}-nak/-nek"
+ "desc": "Adjon meg egy új nevet neki: {{name}}"
},
"details": {
"subLabelScore": "Alcimke érték",
@@ -42,12 +42,12 @@
"title": "Gyűjtemény létrehozása",
"desc": "Új gyűjtemény létrehozása",
"new": "Új arc létrhozása",
- "nextSteps": "A jó alap készítéséhez:Célterület keretek
Világoszöld keretek jelennek meg a képkocka azon területein, amelyek az objektumérzékelőnek elküldésre kerülnek.
" + }, + "paths": { + "title": "Útvonalak", + "desc": "A követett objektum útvonalához tartozó jelentősebb pontok megjelenítése", + "tips": "Útvonalak
A vonalak és körök jelzik a követett objektum életciklusa során érintett jelentősebb pontokat.
" + }, + "openCameraWebUI": "Nyissa meg a {{camera}} webes felületét", + "audio": { + "title": "Hang", + "noAudioDetections": "Nincs hangérzékelés", + "score": "pontszám", + "currentRMS": "Aktuális effektív érték", + "currentdbFS": "Aktuális dbFS" } }, "motionDetectionTuner": { @@ -616,6 +636,224 @@ "success": "Az Ellenőrzési Kategorizálás beállításai elmentésre kerültek. A módosítások alkalmazásához indítsa újra a Frigate-et." } }, - "title": "Kamera Beállítások" + "title": "Kamera Beállítások", + "object_descriptions": { + "title": "Generatív AI Tárgy Leírások", + "desc": "Ideiglenesen engedélyezze/tiltsa le a generatív AI objektumleírásokat ehhez a kamerához. Letiltás esetén a rendszer nem kéri le a mesterséges intelligencia által generált leírásokat a kamerán követett objektumokhoz." + }, + "addCamera": "Új Kamera Hozzáadása", + "editCamera": "Kamera Szerkesztése:", + "selectCamera": "Válasszon ki egy Kamerát", + "backToSettings": "Vissza a Kamera Beállításokhoz", + "cameraConfig": { + "add": "Kamera Hozzáadása", + "edit": "Kamera Szerkesztése", + "name": "Kamera Neve", + "nameRequired": "Kamera nevének megadása szükséges", + "description": "Konfigurálja a kamera beállításait, beleértve a stream bemeneteket és szerepeket.", + "nameInvalid": "A kamera neve csak betűket, számokat, aláhúzásjeleket vagy kötőjeleket tartalmazhat", + "namePlaceholder": "pl: bejarati_ajto", + "enabled": "Engedélyezve", + "ffmpeg": { + "inputs": "Bemeneti Adatfolyamok", + "path": "Adatfolyam útvonal", + "pathRequired": "Adatfolyam útvonal szükséges", + "pathPlaceholder": "rtsp://...", + "roles": "Szerepkörök", + "rolesRequired": "Legalább egy szerepkör megadása kötelező", + "rolesUnique": "Minden szerepkör (hang, érzékelés, rögzítés) csak egy adatfolyamhoz rendelhető hozzá", + "addInput": "Bejövő Adatfolyam Hozzáadása", + "removeInput": "Bejövő Adatfolyam Eltávolítása", + "inputsRequired": "Legalább egy bemeneti adatfolyam szükséges" + }, + "toast": { + "success": "A következő kamera sikeresen mentve: {{cameraName}}" + }, + "nameLength": "A kamera nevének kevesebbnek kell lennie 24 karakternél." + }, + "review_descriptions": { + "title": "Generatív MI Áttekintési Leírások", + "desc": "Ideiglenesen engedélyezze/tiltsa le a generatív mesterséges intelligencia által generált leírásokat ehhez a kamerához. Letiltás esetén a mesterséges intelligencia által generált leírások nem lesznek lekérve a kamerán található elemhez." + } + }, + "triggers": { + "documentTitle": "Trigger-ek", + "management": { + "title": "Triggerek kezelése", + "desc": "A(z) {{camera}} nevű kamera triggereinek kezelése. A bélyegkép típussal a kiválasztott követett objektumhoz hasonló bélyegképekre, a leírás típussal pedig a megadott szöveghez hasonló leírásokra aktiválhatja a funkciót." + }, + "addTrigger": "Trigger hozzáadása", + "table": { + "name": "Név", + "type": "Típus", + "content": "Tartalom", + "threshold": "Határérték", + "actions": "Akciók", + "noTriggers": "Nincsenek konfigurált triggerek ehhez a kamerához.", + "edit": "Szerkesztés", + "deleteTrigger": "Trigger törlése", + "lastTriggered": "Utoljára triggerelve" + }, + "type": { + "thumbnail": "Bélyegkép", + "description": "Leírás" + }, + "actions": { + "alert": "Megjelölés Riasztásként", + "notification": "Értesítés küldése" + }, + "dialog": { + "createTrigger": { + "title": "Trigger létrehozása", + "desc": "Hozz létre egy triggert a(z) {{camera}} kamerához" + }, + "editTrigger": { + "title": "Trigger Szerkesztése", + "desc": "Trigger beállítások szerkesztése a következő kamerán: {{camera}}" + }, + "deleteTrigger": { + "title": "Trigger Törlése", + "desc": "Biztosan törölni szeretné a(z){{triggerName}} triggert? Ez a művelet nem vonható vissza." + }, + "form": { + "name": { + "title": "Név", + "placeholder": "Add meg a trigger nevét", + "error": { + "minLength": "A névnek minimum 2 karakter hosszúnak kell lennie.", + "invalidCharacters": "A név csak betűket, számokat, aláhúzásjeleket és kötőjeleket tartalmazhat.", + "alreadyExists": "Már létezik egy ilyen nevű trigger ehhez a kamerához." + } + }, + "enabled": { + "description": "Engedélyezze vagy tiltsa le ezt a triggert" + }, + "type": { + "title": "Típus", + "placeholder": "Válaszd ki a trigger típusát" + }, + "content": { + "title": "Tartalom", + "imagePlaceholder": "Válassz egy képet", + "textPlaceholder": "Írja be a szöveges tartalmat", + "imageDesc": "Válasszon ki egy képet, amely aktiválja ezt a műveletet, amikor a rendszer hasonló képet észlel.", + "textDesc": "Írjon be egy szöveget, amely aktiválja ezt a műveletet, amikor a rendszer hasonló követett objektumleírást észlel.", + "error": { + "required": "Tartalom megadása kötelező." + } + }, + "threshold": { + "title": "Határérték", + "error": { + "min": "A határértéknek 0-nál nagyobbnak kell lennie", + "max": "A határérték legfeljebb 1 lehet" + } + }, + "actions": { + "title": "Akciók", + "desc": "Alapértelmezés szerint a Frigate minden trigger esetén MQTT üzenetet küld. Válasszon ki egy további műveletet, amelyet a trigger aktiválásakor végre kell hajtani.", + "error": { + "min": "Legalább egy műveletet ki kell választani." + } + }, + "friendly_name": { + "title": "Barátságos név", + "placeholder": "Nevezd meg vagy írd le ezt a triggert", + "description": "Egy opcionális felhasználóbarát név vagy leíró szöveg ehhez az eseményindítóhoz." + } + } + }, + "toast": { + "success": { + "createTrigger": "A trigger sikeresen létrehozva: {{name}}.", + "updateTrigger": "A trigger sikeresen módosítva: {{name}}.", + "deleteTrigger": "A trigger sikeresen törölve: {{name}}." + }, + "error": { + "createTriggerFailed": "A trigger létrehozása sikertelen: {{errorMessage}}", + "updateTriggerFailed": "A trigger módosítása sikertelen: {{errorMessage}}", + "deleteTriggerFailed": "A trigger törlése sikertelen: {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "Szemantikus keresés le van tiltva", + "desc": "A Triggerek használatához engedélyezni kell a szemantikus keresést." + }, + "wizard": { + "steps": { + "nameAndType": "Név és típus", + "configureData": "Configurációs adatok" + } + } + }, + "roles": { + "management": { + "title": "Megtekintői szerepkör-kezelés", + "desc": "Kezelje az egyéni nézői szerepköröket és a kamera-hozzáférési engedélyeiket ehhez a Frigate-példányhoz." + }, + "addRole": "Szerepkör hozzáadása", + "table": { + "role": "Szerepkör", + "cameras": "Kamerák", + "actions": "Akciók", + "noRoles": "Nem találhatók egyéni szerepkörök.", + "editCameras": "Kamerák módosítása", + "deleteRole": "Szerepkör törlése" + }, + "toast": { + "success": { + "createRole": "Szerepkör létrehozva: {{role}}", + "updateCameras": "Kamerák frissítve a szerepkörhöz: {{role}}", + "deleteRole": "Szerepkör sikeresen törölve: {{role}}", + "userRolesUpdated_one": "{{count}} felhasználó, akit ehhez a szerepkörhöz rendeltünk, frissült „néző”-re, amely hozzáféréssel rendelkezik az összes kamerához.", + "userRolesUpdated_other": "" + }, + "error": { + "createRoleFailed": "Nem sikerült létrehozni a szerepkört: {{errorMessage}}", + "updateCamerasFailed": "Nem sikerült frissíteni a kamerákat: {{errorMessage}}", + "deleteRoleFailed": "Nem sikerült törölni a szerepkört: {{errorMessage}}", + "userUpdateFailed": "Nem sikerült frissíteni a felhasználói szerepköröket: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Új szerepkör létrehozása", + "desc": "Adjon hozzá egy új szerepkört, és adja meg a kamera hozzáférési engedélyeit." + }, + "editCameras": { + "title": "Szerepkör kamerák szerkesztése", + "desc": "Frissítse a kamerahozzáférést a(z) {{role}} szerepkörhöz." + }, + "deleteRole": { + "title": "Szerepkör törlése", + "desc": "Ez a művelet nem vonható vissza. Ez véglegesen törli a szerepkört, és az ezzel a szerepkörrel rendelkező összes felhasználót a „megtekintő” szerepkörhöz rendeli, amivel a megtekintő hozzáférhet az összes kamerához.", + "warn": "Biztosan törölni szeretnéd a(z) {{role}} szerepkört?", + "deleting": "Törlés..." + }, + "form": { + "role": { + "title": "Szerepkör neve", + "placeholder": "Adja meg a szerepkör nevét", + "desc": "Csak betűk, számok, pontok és aláhúzásjelek engedélyezettek.", + "roleIsRequired": "A szerepkör nevének megadása kötelező", + "roleOnlyInclude": "A szerepkör neve csak betűket, számokat , . vagy _ karaktereket tartalmazhat", + "roleExists": "Már létezik egy ilyen nevű szerepkör." + }, + "cameras": { + "title": "Kamerák", + "desc": "Válassza ki azokat a kamerákat, amelyekhez ennek a szerepkörnek hozzáférése van. Legalább egy kamera megadása szükséges.", + "required": "Legalább egy kamerát ki kell választani." + } + } + } + }, + "cameraWizard": { + "title": "Kamera hozzáadása", + "description": "Kövesse az alábbi lépéseket, hogy új kamerát adjon hozzá a Frigate telepítéséhez.", + "steps": { + "nameAndConnection": "Név & adatkapcsolat", + "streamConfiguration": "Stream beállítások", + "validationAndTesting": "Validálás és tesztelés" + } } } diff --git a/web/public/locales/hu/views/system.json b/web/public/locales/hu/views/system.json index 847ac7c83..204d85571 100644 --- a/web/public/locales/hu/views/system.json +++ b/web/public/locales/hu/views/system.json @@ -87,7 +87,8 @@ "inferenceSpeed": "Érzékelők Inferencia Sebessége", "cpuUsage": "Érzékelő CPU Kihasználtság", "memoryUsage": "Érzékelő Memória Kihasználtság", - "temperature": "Érzékelő Hőmérséklete" + "temperature": "Érzékelő Hőmérséklete", + "cpuUsageInformation": "A detektálási modellekbe érkező és onnan távozó bemeneti és kimeneti adatok előkészítéséhez használt CPU. Ez az érték nem méri a következtetési kihasználtságot, még GPU vagy gyorsító használata esetén sem." }, "hardwareInfo": { "title": "Hardver Infó", @@ -120,12 +121,19 @@ "gpuEncoder": "GPU Enkóder", "gpuDecoder": "GPU Dekóder", "npuUsage": "NPU Kihasználtság", - "npuMemory": "NPU Memória" + "npuMemory": "NPU Memória", + "intelGpuWarning": { + "message": "GPU statisztika nem érhető el" + } }, "otherProcesses": { "processMemoryUsage": "Folyamat Memória Kihasználtság", "title": "Egyéb Folyamatok", - "processCpuUsage": "Folyamat CPU Kihasználtság" + "processCpuUsage": "Folyamat CPU Kihasználtság", + "series": { + "go2rtc": "go2rtc", + "recording": "felvétel" + } } }, "storage": { @@ -147,6 +155,10 @@ "title": "Felhasználatlan", "tips": "Ez az érték nem feltétlenül tükrözi pontosan a Frigate számára elérhető szabad helyet, ha a meghajtón egyéb fájlok is tárolva vannak a Frigate felvételein kívül. A Frigate nem követi a tárhelyhasználatot a saját felvételein kívül." } + }, + "shm": { + "title": "SHM (megosztott memória) kiosztás", + "warning": "A jelenlegi SHM mérete ({{total}}MB) túl kicsi. Növeld meg minimum ennyivel: {{min_shm}}MB." } }, "enrichments": { @@ -174,7 +186,8 @@ "detectIsSlow": "{{detect}} lassú ({{speed}} ms)", "reindexingEmbeddings": "Beágyazások újra indexelése ({{processed}}% kész)", "ffmpegHighCpuUsage": "{{camera}}-nak/-nek magas FFmpeg CPU felhasználása ({{ffmpegAvg}}%)", - "detectHighCpuUsage": "A(z) {{camera}} kameránál magas az észlelési CPU-használat ({{detectAvg}}%)" + "detectHighCpuUsage": "A(z) {{camera}} kameránál magas az észlelési CPU-használat ({{detectAvg}}%)", + "shmTooLow": "A /dev/shm részére foglalt területet ({{total}} MB) legalább {{min}} MB-ra kell növelni." }, "lastRefreshed": "Utoljára frissítve: " } diff --git a/web/public/locales/id/audio.json b/web/public/locales/id/audio.json index 0d46db1e1..cb3f2539f 100644 --- a/web/public/locales/id/audio.json +++ b/web/public/locales/id/audio.json @@ -27,5 +27,65 @@ "bicycle": "Sepeda", "bus": "Bis", "train": "Kereta", - "boat": "Kapal" + "boat": "Kapal", + "sneeze": "Bersin", + "run": "Lari", + "footsteps": "Langkah kaki", + "chewing": "Mengunyah", + "biting": "Menggigit", + "stomach_rumble": "Perut Keroncongan", + "burping": "Sendawa", + "hiccup": "Cegukan", + "fart": "Kentut", + "hands": "Tangan", + "heartbeat": "Detak Jantung", + "applause": "Tepuk Tangan", + "chatter": "Obrolan", + "children_playing": "Anak-Anak Bermain", + "animal": "Binatang", + "pets": "Peliharaan", + "dog": "Anjing", + "bark": "Gonggongan", + "howl": "Melolong", + "cat": "Kucing", + "meow": "Meong", + "livestock": "Hewan Ternak", + "horse": "Kuda", + "cattle": "Sapi", + "pig": "Babi", + "goat": "Kambing", + "sheep": "Domba", + "chicken": "Ayam", + "cluck": "Berkokok", + "cock_a_doodle_doo": "Kukuruyuk", + "turkey": "Kalkun", + "duck": "Bebek", + "quack": "Kwek", + "goose": "Angsa", + "wild_animals": "Hewan Liar", + "bird": "Burung", + "pigeon": "Merpati", + "crow": "Gagak", + "owl": "Burung Hantu", + "flapping_wings": "Kepakan Sayap", + "dogs": "Anjing", + "insect": "Serangga", + "cricket": "Jangkrik", + "mosquito": "Nyamuk", + "fly": "Lalat", + "frog": "Katak", + "snake": "Ular", + "music": "Musik", + "musical_instrument": "Alat Musik", + "guitar": "Gitar", + "electric_guitar": "Gitar Elektrik", + "acoustic_guitar": "Gitar Akustik", + "strum": "Genjreng", + "banjo": "Banjo", + "snoring": "Ngorok", + "cough": "Batuk", + "clapping": "Tepukan", + "camera": "Kamera", + "wheeze": "Nafas", + "gasp": "Tersedak" } diff --git a/web/public/locales/id/common.json b/web/public/locales/id/common.json index afe3a285c..b1498de07 100644 --- a/web/public/locales/id/common.json +++ b/web/public/locales/id/common.json @@ -9,6 +9,23 @@ "untilForTime": "Hingga {{time}}", "last7": "7 hari terakhir", "last14": "14 hari terakhir", - "last30": "30 hari terakhir" - } + "last30": "30 hari terakhir", + "thisWeek": "Minggu Ini", + "never": "Tidak Pernah", + "lastWeek": "Minggu Lalu", + "thisMonth": "Bulan Ini", + "lastMonth": "Bulan Lalu", + "5minutes": "5 menit", + "10minutes": "10 menit", + "30minutes": "30 menit", + "1hour": "1 jam", + "12hours": "12 jam", + "24hours": "24 jam", + "pm": "pm", + "am": "am", + "yr": "{{time}} tahun", + "year_other": "{{time}} tahun", + "mo": "{{time}} bulan" + }, + "readTheDocumentation": "Baca dokumentasi" } diff --git a/web/public/locales/id/components/auth.json b/web/public/locales/id/components/auth.json index 0bc931d99..742e3111a 100644 --- a/web/public/locales/id/components/auth.json +++ b/web/public/locales/id/components/auth.json @@ -4,12 +4,13 @@ "password": "Kata sandi", "login": "Masuk", "errors": { - "usernameRequired": "Wajib Menggunakan Username", - "passwordRequired": "Wajib memakai Password", + "usernameRequired": "Username diperlukan", + "passwordRequired": "Password diperlukan", "rateLimit": "Melewati batas permintaan. Coba lagi nanti.", "loginFailed": "Gagal Masuk", "unknownError": "Eror tidak diketahui. Mohon lihat log.", "webUnknownError": "Eror tidak diketahui. Mohon lihat log konsol." - } + }, + "firstTimeLogin": "Mencoba masuk untuk pertama kali? Kredensial sudah dicetak di dalam riwayat Frigate." } } diff --git a/web/public/locales/id/components/camera.json b/web/public/locales/id/components/camera.json index da128850f..de7759f34 100644 --- a/web/public/locales/id/components/camera.json +++ b/web/public/locales/id/components/camera.json @@ -15,8 +15,39 @@ "placeholder": "Masukkan nama…", "errorMessage": { "mustLeastCharacters": "Nama grup kamera minimal harus 2 karakter.", - "exists": "Nama grup kamera sudah ada." + "exists": "Nama grup kamera sudah ada.", + "nameMustNotPeriod": "Nama grup kamera tidak boleh ada titik.", + "invalid": "Nama grup kamera tidak valid." + } + }, + "cameras": { + "label": "Kamera", + "desc": "Pilih kamera untuk grup ini." + }, + "icon": "Ikon", + "success": "Grup kamera {{name}} telah disimpan.", + "camera": { + "birdseye": "Mata Elang", + "setting": { + "label": "Pengaturan Streaming Kamera", + "title": "Pengaturan Kamera {{cameraName}}", + "desc": "Ubah pengaturan streaming untuk dasbor grup kamera ini. Pengaturan ini spesifik untuk perangkat / browser tertentu.", + "audioIsAvailable": "Terdapat audio untuk stream ini", + "audioIsUnavailable": "Tidak terdapat audio untuk stream ini", + "audio": { + "tips": { + "title": "Audio harus dikeluarkan dari kamera Anda dan dikonfigurasi di go2rtc untuk stream ini." + } + }, + "stream": "Siaran", + "placeholder": "Pilih stream", + "streamMethod": { + "label": "Metode Streaming" + } } } + }, + "debug": { + "boundingBox": "Batas Kotak" } } diff --git a/web/public/locales/id/components/dialog.json b/web/public/locales/id/components/dialog.json index 5d5f20fb8..07eda62d2 100644 --- a/web/public/locales/id/components/dialog.json +++ b/web/public/locales/id/components/dialog.json @@ -17,9 +17,46 @@ "review": { "question": { "label": "Konfirmasi label ini untuk Frigate Plus", - "ask_a": "Apakah objek ini adalah sebuah{{label}}?"
+ "ask_a": "Apakah objek ini adalah sebuah{{label}}?",
+ "ask_an": "Apakah objek ini {{label}}?",
+ "ask_full": "Apakah ini object {{untranslatedLabel}} ({{translatedLabel}})?"
+ },
+ "state": {
+ "submitted": "Terkirim"
}
}
+ },
+ "video": {
+ "viewInHistory": "Lihat di Histori"
+ }
+ },
+ "export": {
+ "time": {
+ "fromTimeline": "Pilih dari Linimasa",
+ "lastHour_other": "{{count}} Jam Terakhir",
+ "custom": "Kustom",
+ "start": {
+ "title": "Waktu Mulai",
+ "label": "Pilih Waktu Mulai"
+ },
+ "end": {
+ "title": "Waktu Akhir",
+ "label": "Pilih Waktu Akhir"
+ }
+ },
+ "name": {
+ "placeholder": "Nama Ekspor"
+ },
+ "select": "Pilih",
+ "export": "Ekspor",
+ "selectOrExport": "Pilih atau Ekspor",
+ "toast": {
+ "success": "Berhasil memulai ekspor. Lihat file pada halaman ekspor."
+ }
+ },
+ "search": {
+ "saveSearch": {
+ "overwrite": "{{searchName}} sudah ada. Menyimpan akan menimpa file yang sudah ada."
}
}
}
diff --git a/web/public/locales/id/components/filter.json b/web/public/locales/id/components/filter.json
index 0ea01e61b..8b39304c4 100644
--- a/web/public/locales/id/components/filter.json
+++ b/web/public/locales/id/components/filter.json
@@ -15,5 +15,43 @@
"title": "Semua Zona",
"short": "Zona"
}
+ },
+ "classes": {
+ "label": "Kelas",
+ "all": {
+ "title": "Semua Kelas"
+ },
+ "count_one": "{{count}} Kelas",
+ "count_other": "{{count}} Kelas"
+ },
+ "dates": {
+ "selectPreset": "Pilih preset…",
+ "all": {
+ "title": "Semua Tanggal",
+ "short": "Tanggal"
+ }
+ },
+ "more": "Lebih Banyak",
+ "reset": {
+ "label": "Atur ulang filter ke default"
+ },
+ "timeRange": "Rentang Waktu",
+ "subLabels": {
+ "label": "Sublabel",
+ "all": "Semua Sublabel"
+ },
+ "attributes": {
+ "label": "Klasifikasi Atribut",
+ "all": "Semua Atribut"
+ },
+ "score": "Skor",
+ "estimatedSpeed": "Perkiraan Kecepatan {{unit}}",
+ "features": {
+ "label": "Fitur"
+ },
+ "cameras": {
+ "all": {
+ "short": "Kamera"
+ }
}
}
diff --git a/web/public/locales/id/components/player.json b/web/public/locales/id/components/player.json
index 097e50a68..0372a797c 100644
--- a/web/public/locales/id/components/player.json
+++ b/web/public/locales/id/components/player.json
@@ -14,7 +14,38 @@
"cameraDisabled": "Kamera dinonaktifkan",
"stats": {
"streamType": {
- "title": "Tipe stream:"
+ "title": "Tipe stream:",
+ "short": "Jenis"
+ },
+ "bandwidth": {
+ "title": "Bandwith:",
+ "short": "Bandwith"
+ },
+ "latency": {
+ "title": "Latensi:",
+ "value": "{{seconds}} detik",
+ "short": {
+ "title": "Latensi",
+ "value": "{{seconds}} detik"
+ }
+ },
+ "totalFrames": "Total Frame:",
+ "droppedFrames": {
+ "title": "Frame Terbuang:",
+ "short": {
+ "title": "Terbuang",
+ "value": "{{droppedFrames}} frame"
+ }
+ },
+ "decodedFrames": "Decoded Frames:",
+ "droppedFrameRate": "Frame Rate Terbuang:"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "Berhasil mengirim frame ke Frigate+"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "Gagal mengirim frame ke Frigate+"
}
}
}
diff --git a/web/public/locales/id/objects.json b/web/public/locales/id/objects.json
index ce7f18a78..e56f051d0 100644
--- a/web/public/locales/id/objects.json
+++ b/web/public/locales/id/objects.json
@@ -8,5 +8,24 @@
"train": "Kereta",
"boat": "Kapal",
"traffic_light": "Lampu Lalu Lintas",
- "fire_hydrant": "Hidran Kebakaran"
+ "fire_hydrant": "Hidran Kebakaran",
+ "animal": "Binatang",
+ "dog": "Anjing",
+ "bark": "Gonggongan",
+ "cat": "Kucing",
+ "horse": "Kuda",
+ "goat": "Kambing",
+ "sheep": "Domba",
+ "bird": "Burung",
+ "street_sign": "Rambu Jalan",
+ "stop_sign": "Tanda Stop",
+ "parking_meter": "Parkir Meter",
+ "bench": "Kursi",
+ "cow": "Sapi",
+ "elephant": "Gajah",
+ "bear": "Beruang",
+ "zebra": "Zebra",
+ "giraffe": "Jerapah",
+ "hat": "Topi",
+ "backpack": "Tas"
}
diff --git a/web/public/locales/id/views/classificationModel.json b/web/public/locales/id/views/classificationModel.json
new file mode 100644
index 000000000..0f0c01261
--- /dev/null
+++ b/web/public/locales/id/views/classificationModel.json
@@ -0,0 +1,47 @@
+{
+ "documentTitle": "Klasifikasi Model - Frigate",
+ "details": {
+ "scoreInfo": "Skor tersebut mewakili rata-rata kepercayaan klasifikasi di seluruh deteksi objek ini."
+ },
+ "button": {
+ "deleteClassificationAttempts": "Hapus Gambar Klasifikasi",
+ "renameCategory": "Ubah Nama Kelas",
+ "deleteCategory": "Hapus Kelas",
+ "deleteImages": "Hapus Gambar",
+ "trainModel": "Latih Model",
+ "addClassification": "Tambah Klasifikasi",
+ "deleteModels": "Hapus Model",
+ "editModel": "Ubah Model"
+ },
+ "tooltip": {
+ "trainingInProgress": "Model dalam training",
+ "noNewImages": "Tidak ada gambar untuk dilatih. Klasifikasikan gambar terlebih dahulu di dataset.",
+ "noChanges": "Tidak ada perubahan dataset sejak latihan terakhir.",
+ "modelNotReady": "Model tidak siap untuk dilatih"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Kelas dihapus",
+ "deletedImage": "Image dihapus",
+ "deletedModel_other": "Berhasil menghapus {{count}} model",
+ "categorizedImage": "Berhasil Mengklasifikasikan Gambar",
+ "trainedModel": "Berhasil melatih model.",
+ "trainingModel": "Berhasil memulai pelatihan model.",
+ "updatedModel": "Berhasil memperbarui konfigurasi model",
+ "renamedCategory": "Berhasil mengganti nama class ke {{name}}"
+ },
+ "error": {
+ "updateModelFailed": "Gagal melakukan perubahan pada model: {{errorMessage}}",
+ "renameCategoryFailed": "Gagal merubah penamaan kelas: {{errorMessage}}",
+ "deleteImageFailed": "Gagal menghapus: {{errorMessage}}",
+ "deleteCategoryFailed": "Gagal menghapus kelas: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Kelas dihapus",
+ "minClassesTitle": "Dilarang menghapus Kelas"
+ },
+ "train": {
+ "titleShort": "Terkini"
+ }
+}
diff --git a/web/public/locales/id/views/configEditor.json b/web/public/locales/id/views/configEditor.json
index 871c35180..a4d7baeaa 100644
--- a/web/public/locales/id/views/configEditor.json
+++ b/web/public/locales/id/views/configEditor.json
@@ -12,5 +12,7 @@
"savingError": "Gagal menyimpan konfigurasi"
}
},
- "confirm": "Keluar tanpa menyimpan?"
+ "confirm": "Keluar tanpa menyimpan?",
+ "safeModeDescription": "Frigate sedang dalam mode aman karena kesalahan validasi konfigurasi.",
+ "safeConfigEditor": "Editor Konfigurasi(Mode Aman)"
}
diff --git a/web/public/locales/id/views/events.json b/web/public/locales/id/views/events.json
index f320bae8f..19a85885f 100644
--- a/web/public/locales/id/views/events.json
+++ b/web/public/locales/id/views/events.json
@@ -9,8 +9,55 @@
"empty": {
"detection": "Tidak ada deteksi untuk ditinjau",
"alert": "Tidak ada peringatan untuk ditinjau",
- "motion": "Data gerakan tidak ditemukan"
+ "motion": "Data gerakan tidak ditemukan",
+ "recordingsDisabled": {
+ "title": "Perekaman harus di aktifkan",
+ "description": "Ulasan item hanya dapat dibuat untuk kamera jika perekaman diaktifkan untuk kamera tersebut."
+ }
},
"timeline.aria": "Pilih timeline",
- "timeline": "Linimasa"
+ "timeline": "Linimasa",
+ "zoomIn": "Perbesar",
+ "zoomOut": "Perkecil",
+ "events": {
+ "label": "Peristiwa-Peristiwa",
+ "aria": "Pilih peristiwa",
+ "noFoundForTimePeriod": "Tidak ada peristiwa dalam periode waktu berikut."
+ },
+ "detail": {
+ "label": "Detil",
+ "noDataFound": "Tidak ada detil data untuk di review",
+ "aria": "Beralih tampilan detil",
+ "trackedObject_one": "{{count}} objek",
+ "trackedObject_other": "{{count}} objek",
+ "noObjectDetailData": "Tidak ada data objek detil tersedia.",
+ "settings": "Pengaturan Tampilan Detil",
+ "alwaysExpandActive": {
+ "title": "Selalu lebarkan yang aktif",
+ "desc": "Selalu perluas detil objek item tinjauan aktif jika tersedia."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Titik terlacak",
+ "clickToSeek": "Klik untuk mencari waktu ini"
+ },
+ "documentTitle": "Tinjauan - Frigate",
+ "recordings": {
+ "documentTitle": "Rekaman - Frigate"
+ },
+ "calendarFilter": {
+ "last24Hours": "24 Jam Terakhir"
+ },
+ "markAsReviewed": "Tandai sebagai sudah ditinjau",
+ "markTheseItemsAsReviewed": "Tandai item-item berikut sebagai sudah ditinjau",
+ "newReviewItems": {
+ "button": "Item Batu Untuk Ditinjau",
+ "label": "Lihat item ulasan baru"
+ },
+ "selected_one": "{{count}} terpilih",
+ "selected_other": "{{count}} terpilih",
+ "camera": "Kamera",
+ "detected": "terdeteksi",
+ "suspiciousActivity": "Aktivitas Mencurigakan",
+ "threateningActivity": "Aktivitas yang Mengancam"
}
diff --git a/web/public/locales/id/views/explore.json b/web/public/locales/id/views/explore.json
index de062e132..b93d4bf61 100644
--- a/web/public/locales/id/views/explore.json
+++ b/web/public/locales/id/views/explore.json
@@ -9,12 +9,38 @@
"estimatedTime": "Perkiraan waktu tersisa:",
"finishingShortly": "Selesai sesaat lagi",
"step": {
- "thumbnailsEmbedded": "Keluku dilampirkan "
+ "thumbnailsEmbedded": "Keluku dilampirkan ",
+ "descriptionsEmbedded": "Deskripsi terlampir: ",
+ "trackedObjectsProcessed": "Objek yang dilacak diproses: "
}
+ },
+ "downloadingModels": {
+ "context": "Frigate sedang mengunduh model embedding yang diperlukan untuk mendukung fitur Pencarian Semantik. Proses ini mungkin memakan waktu beberapa menit tergantung pada kecepatan koneksi jaringan Anda.",
+ "setup": {
+ "visionModel": "Model vision",
+ "visionModelFeatureExtractor": "Ekstraktor fitur model visi",
+ "textModel": "Model teks",
+ "textTokenizer": "Teks tokenizer"
+ },
+ "tips": {
+ "context": "Anda mungkin ingin mengindeks ulang embeddings dari objek yang Anda lacak setelah model-model tersebut diunduh."
+ },
+ "error": "Terjadi eror. Periksa log Frigate."
}
},
"details": {
"timestamp": "Stempel waktu"
},
- "exploreMore": "Eksplor lebih jauh objek-objek {{label}}"
+ "exploreMore": "Eksplor lebih jauh objek-objek {{label}}",
+ "trackedObjectDetails": "Detail Objek Terlacak",
+ "type": {
+ "details": "detail",
+ "snapshot": "tangkapan layar",
+ "thumbnail": "thumbnail",
+ "video": "video",
+ "tracking_details": "detail pelacakan"
+ },
+ "trackingDetails": {
+ "title": "Detail Pelacakan"
+ }
}
diff --git a/web/public/locales/id/views/exports.json b/web/public/locales/id/views/exports.json
index ebb88a9f7..043c313de 100644
--- a/web/public/locales/id/views/exports.json
+++ b/web/public/locales/id/views/exports.json
@@ -1,17 +1,23 @@
{
"documentTitle": "Expor - Frigate",
"search": "Cari",
- "noExports": "Tidak bisa mengekspor",
+ "noExports": "Ekspor tidak ditemukan",
"deleteExport": "Hapus Ekspor",
"deleteExport.desc": "Apakah Anda yakin ingin menghapus {{exportName}}?",
"editExport": {
- "title": "Ganti Nama saat Ekspor",
- "desc": "Masukkan nama baru untuk mengekspor.",
+ "title": "Ganti Nama Ekspor",
+ "desc": "Masukkan nama baru untuk ekspor ini.",
"saveExport": "Simpan Ekspor"
},
"toast": {
"error": {
- "renameExportFailed": "Gagal mengganti nama export: {{errorMessage}}"
+ "renameExportFailed": "Gagal mengganti nama ekspor: {{errorMessage}}"
}
+ },
+ "tooltip": {
+ "shareExport": "Bagikan Ekspor",
+ "downloadVideo": "Unduh Video",
+ "editName": "Ubah nama",
+ "deleteExport": "Hapus ekspor"
}
}
diff --git a/web/public/locales/id/views/faceLibrary.json b/web/public/locales/id/views/faceLibrary.json
index ff1fd4b61..70b2a419a 100644
--- a/web/public/locales/id/views/faceLibrary.json
+++ b/web/public/locales/id/views/faceLibrary.json
@@ -1,6 +1,6 @@
{
"description": {
- "addFace": "Tambah ke koleksi Pustaka Wajah.",
+ "addFace": "Tambah ke koleksi Pustaka Wajah dengan men-upload gambar pertama anda.",
"placeholder": "Masukkan Nama untuk koleksi ini",
"invalidName": "Nama tidak valid. Nama hanya dapat berisi huruf, angka, spasi, apostrof, garis bawah, dan tanda hubung."
},
@@ -18,13 +18,76 @@
"createFaceLibrary": {
"desc": "Buat koleksi baru",
"title": "Buat Koleksi",
- "nextSteps": "Untuk membangun fondasi yang kuat:clean_copy Istantanee"
+ "cleanCopySnapshots": "Istantanee clean_copy"
},
"desc": "Per inviare a Frigate+ è necessario che nella configurazione siano abilitate sia le istantanee che le istantanee clean_copy.",
"documentation": "Leggi la documentazione",
@@ -85,9 +87,9 @@
"desc": "Mostra un riquadro della regione di interesse inviata al rilevatore di oggetti"
},
"noObjects": "Nessun oggetto",
- "title": "Correzioni",
- "desc": "La vista di correzione mostra una vista in tempo reale degli oggetti tracciati e delle relative statistiche. L'elenco degli oggetti mostra un riepilogo ritardato degli oggetti rilevati.",
- "debugging": "Correzioni",
+ "title": "Debug",
+ "desc": "La vista di debug mostra in tempo reale gli oggetti tracciati e le relative statistiche. L'elenco degli oggetti mostra un riepilogo in differita degli oggetti rilevati.",
+ "debugging": "Debugging",
"objectList": "Elenco degli oggetti",
"mask": {
"desc": "Mostra i poligoni della maschera di movimento",
@@ -101,7 +103,20 @@
"zones": {
"title": "Zone",
"desc": "Mostra un contorno di tutte le zone definite"
- }
+ },
+ "paths": {
+ "title": "Percorsi",
+ "desc": "Mostra i punti significativi del percorso dell'oggetto tracciato",
+ "tips": "Percorsi
Linee e cerchi indicheranno i punti significativi in cui l'oggetto tracciato si è spostato durante il suo ciclo di vita.
" + }, + "audio": { + "title": "Audio", + "currentdbFS": "dbFS correnti", + "noAudioDetections": "Nessun rilevamento audio", + "score": "punteggio", + "currentRMS": "RMS attuale" + }, + "openCameraWebUI": "Apri l'interfaccia utente Web di {{camera}}" }, "masksAndZones": { "motionMasks": { @@ -128,8 +143,8 @@ "add": "Nuova maschera di movimento", "toast": { "success": { - "title": "{{polygonName}} è stato salvato. Riavvia Frigate per applicare le modifiche.", - "noName": "La maschera di movimento è stata salvata. Riavvia Frigate per applicare le modifiche." + "title": "{{polygonName}} è stato salvato.", + "noName": "La maschera di movimento è stata salvata." } } }, @@ -140,7 +155,8 @@ "mustNotBeSameWithCamera": "Il nome della zona non deve essere uguale al nome della telecamera.", "mustBeAtLeastTwoCharacters": "Il nome della zona deve essere composto da almeno 2 caratteri.", "alreadyExists": "Per questa telecamera esiste già una zona con questo nome.", - "mustNotContainPeriod": "Il nome della zona non deve contenere punti." + "mustNotContainPeriod": "Il nome della zona non deve contenere punti.", + "mustHaveAtLeastOneLetter": "Il nome della zona deve contenere almeno una lettera." } }, "distance": { @@ -223,7 +239,7 @@ "name": { "inputPlaceHolder": "Inserisci un nome…", "title": "Nome", - "tips": "Il nome deve essere composto da almeno 2 caratteri e non deve essere il nome di una telecamera o di un'altra zona." + "tips": "Il nome deve essere composto da almeno 2 caratteri, contenere almeno una lettera e non deve essere il nome di una telecamera o di un'altra zona di questa telecamera." }, "clickDrawPolygon": "Fai clic per disegnare un poligono sull'immagine.", "point_one": "{{count}} punto", @@ -245,7 +261,7 @@ }, "allObjects": "Tutti gli oggetti", "toast": { - "success": "La zona ({{zoneName}}) è stata salvata. Riavvia Frigate per applicare le modifiche." + "success": "La zona ({{zoneName}}) è stata salvata." } }, "objectMasks": { @@ -267,8 +283,8 @@ }, "toast": { "success": { - "noName": "La maschera oggetto è stata salvata. Riavvia Frigate per applicare le modifiche.", - "title": "{{polygonName}} è stato salvato. Riavvia Frigate per applicare le modifiche." + "noName": "La maschera oggetto è stata salvata.", + "title": "{{polygonName}} è stato salvato." } }, "label": "Maschere di oggetti", @@ -292,7 +308,7 @@ "regardlessOfZoneObjectDetectionsTips": "Tutti gli oggetti {{detectionsLabels}} non categorizzati su {{cameraName}} verranno mostrati come Rilevamenti, indipendentemente dalla zona in cui si trovano." }, "title": "Classificazione della revisione", - "desc": "Frigate categorizza gli elementi di revisione come Avvisi e Rilevamenti. Per impostazione predefinita, tutti gli oggetti persona e auto sono considerati Avvisi. Puoi perfezionare la categorizzazione degli elementi di revisione configurando le zone desiderate.", + "desc": "Frigate categorizza gli elementi di revisione come Avvisi e Rilevamenti. Per impostazione predefinita, tutti gli oggetti persona e automobile sono considerati Avvisi. Puoi perfezionare la categorizzazione degli elementi di revisione configurando le zone desiderate.", "objectAlertsTips": "Tutti gli oggetti {{alertsLabels}} su {{cameraName}} verranno mostrati come Avvisi.", "toast": { "success": "La configurazione della classificazione di revisione è stata salvata. Riavvia Frigate per applicare le modifiche." @@ -305,7 +321,7 @@ "unsavedChanges": "Impostazioni di classificazione delle revisioni non salvate per {{camera}}" }, "streams": { - "desc": "Disattiva temporaneamente una telecamera fino al riavvio di Frigate. La disattivazione completa di una telecamera interrompe l'elaborazione dei flussi da parte di Frigate. Rilevamento, registrazione e correzioni non saranno disponibili.{{label}} ですか?",
+ "ask_an": "このオブジェクトは {{label}} ですか?",
+ "ask_full": "このオブジェクトは {{untranslatedLabel}}({{translatedLabel}})ですか?"
+ },
+ "state": {
+ "submitted": "送信済み"
+ }
+ }
+ },
+ "video": {
+ "viewInHistory": "履歴で表示"
+ }
+ },
+ "export": {
+ "time": {
+ "fromTimeline": "タイムラインから選択",
+ "lastHour_other": "直近{{count}}時間",
+ "custom": "カスタム",
+ "start": {
+ "title": "開始時刻",
+ "label": "開始時刻を選択"
+ },
+ "end": {
+ "title": "終了時刻",
+ "label": "終了時刻を選択"
+ }
+ },
+ "name": {
+ "placeholder": "書き出しに名前を付ける"
+ },
+ "select": "選択",
+ "export": "書き出し",
+ "selectOrExport": "選択または書き出し",
+ "toast": {
+ "success": "書き出しを開始しました。出力ページでファイルを確認できます。",
+ "error": {
+ "failed": "書き出しの開始に失敗しました: {{error}}",
+ "endTimeMustAfterStartTime": "終了時間は開始時間より後である必要があります",
+ "noVaildTimeSelected": "有効な時間範囲が選択されていません"
+ },
+ "view": "表示"
+ },
+ "fromTimeline": {
+ "saveExport": "書き出しを保存",
+ "previewExport": "書き出しをプレビュー"
+ }
+ },
+ "streaming": {
+ "label": "ストリーム",
+ "restreaming": {
+ "disabled": "このカメラではリストリーミングは有効になっていません。",
+ "desc": {
+ "title": "このカメラで追加のライブビューと音声を利用するには go2rtc をセットアップしてください。"
+ }
+ },
+ "showStats": {
+ "label": "ストリーム統計を表示",
+ "desc": "有効にすると、カメラ映像に統計情報をオーバーレイ表示します。"
+ },
+ "debugView": "デバッグビュー"
+ },
+ "search": {
+ "saveSearch": {
+ "label": "検索を保存",
+ "desc": "この保存済み検索の名前を入力してください。",
+ "placeholder": "検索名を入力",
+ "overwrite": "{{searchName}} は既に存在します。保存すると上書きされます。",
+ "success": "検索({{searchName}})を保存しました。",
+ "button": {
+ "save": {
+ "label": "この検索を保存"
+ }
+ }
+ }
+ },
+ "recording": {
+ "confirmDelete": {
+ "title": "削除の確認",
+ "desc": {
+ "selected": "このレビュー項目に関連付けられた録画動画をすべて削除してもよろしいですか?detect ストリームでフレームが受信されていません。エラーログを確認してください"
+ },
+ "submitFrigatePlus": {
+ "title": "このフレームを Frigate+ に送信しますか?",
+ "submit": "送信"
+ },
+ "livePlayerRequiredIOSVersion": "このライブストリームタイプには iOS 17.1 以上が必要です。",
+ "cameraDisabled": "カメラは無効です",
+ "stats": {
+ "streamType": {
+ "title": "ストリームタイプ:",
+ "short": "タイプ"
+ },
+ "bandwidth": {
+ "title": "帯域:",
+ "short": "帯域"
+ },
+ "latency": {
+ "title": "遅延:",
+ "value": "{{seconds}} 秒",
+ "short": {
+ "title": "遅延",
+ "value": "{{seconds}} 秒"
+ }
+ },
+ "totalFrames": "総フレーム:",
+ "droppedFrames": {
+ "title": "ドロップしたフレーム:",
+ "short": {
+ "title": "ドロップ",
+ "value": "{{droppedFrames}} フレーム"
+ }
+ },
+ "decodedFrames": "デコードしたフレーム:",
+ "droppedFrameRate": "ドロップしたフレームレート:"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "フレームを Frigate+ に送信しました"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "フレームの Frigate+ への送信に失敗しました"
+ }
+ }
}
diff --git a/web/public/locales/ja/objects.json b/web/public/locales/ja/objects.json
index 0f9ddaa73..c3e41af3f 100644
--- a/web/public/locales/ja/objects.json
+++ b/web/public/locales/ja/objects.json
@@ -1,5 +1,120 @@
{
"bicycle": "自転車",
- "car": "自動車",
- "person": "人物"
+ "car": "車",
+ "person": "人",
+ "motorcycle": "オートバイ",
+ "airplane": "飛行機",
+ "animal": "動物",
+ "dog": "犬",
+ "bark": "吠え声",
+ "cat": "猫",
+ "horse": "馬",
+ "goat": "ヤギ",
+ "sheep": "羊",
+ "bird": "鳥",
+ "mouse": "マウス",
+ "keyboard": "キーボード",
+ "vehicle": "車両",
+ "boat": "ボート",
+ "bus": "バス",
+ "train": "電車",
+ "skateboard": "スケートボード",
+ "door": "ドア",
+ "blender": "ミキサー",
+ "sink": "流し台",
+ "hair_dryer": "ヘアドライヤー",
+ "toothbrush": "歯ブラシ",
+ "scissors": "はさみ",
+ "clock": "時計",
+ "traffic_light": "信号機",
+ "fire_hydrant": "消火栓",
+ "street_sign": "道路標識",
+ "stop_sign": "一時停止標識",
+ "parking_meter": "駐車メーター",
+ "bench": "ベンチ",
+ "cow": "牛",
+ "elephant": "象",
+ "bear": "クマ",
+ "zebra": "シマウマ",
+ "giraffe": "キリン",
+ "hat": "帽子",
+ "backpack": "バックパック",
+ "umbrella": "傘",
+ "shoe": "靴",
+ "eye_glasses": "メガネ",
+ "handbag": "ハンドバッグ",
+ "tie": "ネクタイ",
+ "suitcase": "スーツケース",
+ "frisbee": "フリスビー",
+ "skis": "スキー板",
+ "snowboard": "スノーボード",
+ "sports_ball": "スポーツボール",
+ "kite": "凧",
+ "baseball_bat": "野球バット",
+ "baseball_glove": "野球グローブ",
+ "surfboard": "サーフボード",
+ "tennis_racket": "テニスラケット",
+ "bottle": "ボトル",
+ "plate": "皿",
+ "wine_glass": "ワイングラス",
+ "cup": "コップ",
+ "fork": "フォーク",
+ "knife": "ナイフ",
+ "spoon": "スプーン",
+ "bowl": "ボウル",
+ "banana": "バナナ",
+ "apple": "リンゴ",
+ "sandwich": "サンドイッチ",
+ "orange": "オレンジ",
+ "broccoli": "ブロッコリー",
+ "carrot": "ニンジン",
+ "hot_dog": "ホットドッグ",
+ "pizza": "ピザ",
+ "donut": "ドーナツ",
+ "cake": "ケーキ",
+ "chair": "椅子",
+ "couch": "ソファ",
+ "potted_plant": "鉢植え",
+ "bed": "ベッド",
+ "mirror": "鏡",
+ "dining_table": "ダイニングテーブル",
+ "window": "窓",
+ "desk": "机",
+ "toilet": "トイレ",
+ "tv": "テレビ",
+ "laptop": "ノートパソコン",
+ "remote": "リモコン",
+ "cell_phone": "携帯電話",
+ "microwave": "電子レンジ",
+ "oven": "オーブン",
+ "toaster": "トースター",
+ "refrigerator": "冷蔵庫",
+ "book": "本",
+ "vase": "花瓶",
+ "teddy_bear": "テディベア",
+ "hair_brush": "ヘアブラシ",
+ "squirrel": "リス",
+ "deer": "シカ",
+ "fox": "キツネ",
+ "rabbit": "ウサギ",
+ "raccoon": "アライグマ",
+ "robot_lawnmower": "ロボット芝刈り機",
+ "waste_bin": "ゴミ箱",
+ "on_demand": "オンデマンド",
+ "face": "顔",
+ "license_plate": "ナンバープレート",
+ "package": "荷物",
+ "bbq_grill": "バーベキューグリル",
+ "amazon": "Amazon",
+ "usps": "USPS",
+ "ups": "UPS",
+ "fedex": "FedEx",
+ "dhl": "DHL",
+ "an_post": "An Post",
+ "purolator": "Purolator",
+ "postnl": "PostNL",
+ "nzpost": "NZPost",
+ "postnord": "PostNord",
+ "gls": "GLS",
+ "dpd": "DPD"
}
diff --git a/web/public/locales/ja/views/classificationModel.json b/web/public/locales/ja/views/classificationModel.json
new file mode 100644
index 000000000..e16f1fce5
--- /dev/null
+++ b/web/public/locales/ja/views/classificationModel.json
@@ -0,0 +1,182 @@
+{
+ "documentTitle": "分類モデル - Frigate",
+ "button": {
+ "deleteImages": "画像を削除",
+ "deleteClassificationAttempts": "分類画像を削除",
+ "renameCategory": "クラス名を変更",
+ "deleteCategory": "クラスを削除",
+ "trainModel": "モデルを学習",
+ "addClassification": "分類を追加",
+ "deleteModels": "モデルを削除",
+ "editModel": "モデルを編集"
+ },
+ "toast": {
+ "success": {
+ "deletedImage": "削除された画像",
+ "categorizedImage": "画像の分類に成功しました",
+ "trainedModel": "モデルを正常に学習させました。",
+ "trainingModel": "モデルのトレーニングを正常に開始しました。",
+ "deletedCategory": "クラスを削除しました",
+ "deletedModel_other": "{{count}} 件のモデルを削除しました",
+ "updatedModel": "モデル設定を更新しました",
+ "renamedCategory": "クラス名を {{name}} に変更しました"
+ },
+ "error": {
+ "deleteImageFailed": "削除に失敗しました: {{errorMessage}}",
+ "deleteCategoryFailed": "クラスの削除に失敗しました: {{errorMessage}}",
+ "deleteModelFailed": "モデルの削除に失敗しました: {{errorMessage}}",
+ "categorizeFailed": "画像の分類に失敗しました: {{errorMessage}}",
+ "trainingFailed": "モデルの学習に失敗しました。Frigate のログを確認してください。",
+ "trainingFailedToStart": "モデルの学習を開始できませんでした: {{errorMessage}}",
+ "updateModelFailed": "モデルの更新に失敗しました: {{errorMessage}}",
+ "renameCategoryFailed": "クラス名の変更に失敗しました: {{errorMessage}}"
+ }
+ },
+ "train": {
+ "titleShort": "Classifications,最近の分類結果を選択,,False,train.aria,,",
+ "title": "最近の分類結果",
+ "aria": "最近の分類結果を選択"
+ },
+ "wizard": {
+ "step1": {
+ "typeObject": "Classification",
+ "typeState": "Classification",
+ "description": "状態モデルは固定カメラ領域の状態変化(例:ドアの開閉)を監視し、オブジェクトモデルは検出されたオブジェクトに分類(例:既知の動物や配達員など)を追加します。",
+ "name": "名前",
+ "namePlaceholder": "モデル名を入力...",
+ "type": "タイプ",
+ "objectLabel": "オブジェクトラベル",
+ "objectLabelPlaceholder": "オブジェクトタイプを選択...",
+ "classificationType": "分類タイプ",
+ "classificationTypeTip": "分類タイプについて",
+ "classificationTypeDesc": "サブラベルはオブジェクトのラベルに追加のテキストを追加します(例:「人: UPS」)。属性は、オブジェクトのメタデータとは別に保存される、検索可能なメタデータです。",
+ "classificationSubLabel": "サブラベル",
+ "classificationAttribute": "属性",
+ "classes": "クラス",
+ "states": "状態",
+ "classesTip": "クラスについて",
+ "classesStateDesc": "カメラ領域の状態を定義します。例: ガレージドアの「開」「閉」。",
+ "classesObjectDesc": "検出されたオブジェクトを分類するための、異なるカテゴリを定義します。例:人物の分類として「delivery_person」「resident」「stranger」など。",
+ "classPlaceholder": "クラス名を入力...",
+ "errors": {
+ "nameRequired": "モデル名は必須です",
+ "nameLength": "モデル名は 64 文字以内で入力してください",
+ "nameOnlyNumbers": "モデル名を数字のみにはできません",
+ "classRequired": "少なくとも 1 つのクラスが必要です",
+ "classesUnique": "クラス名は一意である必要があります",
+ "noneNotAllowed": "「none」というクラス名は使用できません",
+ "stateRequiresTwoClasses": "状態モデルには少なくとも 2 つのクラスが必要です",
+ "objectLabelRequired": "オブジェクトラベルを選択してください",
+ "objectTypeRequired": "分類タイプを選択してください"
+ }
+ },
+ "title": "新しい分類を作成",
+ "steps": {
+ "nameAndDefine": "名前と定義",
+ "stateArea": "状態エリア",
+ "chooseExamples": "例を選択"
+ },
+ "step2": {
+ "description": "カメラを選択し、それぞれの監視エリアを定義します。モデルはこれらのエリアの状態を分類します。",
+ "cameras": "カメラ",
+ "selectCamera": "カメラを選択",
+ "noCameras": "+ をクリックしてカメラを追加",
+ "selectCameraPrompt": "リストからカメラを選択して監視エリアを定義します"
+ },
+ "step3": {
+ "selectImagesPrompt": "{{className}} の画像をすべて選択",
+ "selectImagesDescription": "画像をクリックして選択します。このクラスの作業が完了したら「続行」をクリックしてください。",
+ "allImagesRequired_other": "すべての画像を分類してください。残り {{count}} 枚です。",
+ "generating": {
+ "title": "サンプル画像を生成中",
+ "description": "Frigate が録画から代表的な画像を抽出しています。しばらくお待ちください..."
+ },
+ "training": {
+ "title": "モデルを学習中",
+ "description": "モデルはバックグラウンドで学習されています。このダイアログを閉じると、学習完了後すぐにモデルが有効になります。"
+ },
+ "retryGenerate": "再生成",
+ "noImages": "サンプル画像が生成されませんでした",
+ "classifying": "分類・学習中...",
+ "trainingStarted": "学習を開始しました",
+ "modelCreated": "モデルを作成しました。不足している状態の画像を「最近の分類」から追加し、モデルを学習してください。",
+ "errors": {
+ "noCameras": "カメラが設定されていません",
+ "noObjectLabel": "オブジェクトラベルが選択されていません",
+ "generateFailed": "例の生成に失敗しました: {{error}}",
+ "generationFailed": "生成に失敗しました。もう一度お試しください。",
+ "classifyFailed": "画像の分類に失敗しました: {{error}}"
+ },
+ "generateSuccess": "サンプル画像を生成しました",
+ "missingStatesWarning": {
+ "title": "状態の例が不足しています",
+ "description": "最良の結果を得るため、すべての状態の例を選択することを推奨します。すべてを選択しなくても続行できますが、全状態に画像が揃うまでモデルは学習されません。続行後、「最近の分類」から不足分を分類し、学習を行ってください。"
+ }
+ }
+ },
+ "details": {
+ "scoreInfo": "このスコアは、このオブジェクトに対するすべての検出結果の分類信頼度の平均を表します。",
+ "none": "なし",
+ "unknown": "不明"
+ },
+ "tooltip": {
+ "trainingInProgress": "モデルは現在学習中です",
+ "noNewImages": "学習に使用できる新しい画像がありません。先にデータセット内の画像を分類してください。",
+ "noChanges": "前回の学習以降、データセットに変更はありません。",
+ "modelNotReady": "モデルはまだ学習可能な状態ではありません"
+ },
+ "deleteCategory": {
+ "title": "クラスを削除",
+ "desc": "クラス {{name}} を削除してもよろしいですか?関連するすべての画像が完全に削除され、モデルの再学習が必要になります。",
+ "minClassesTitle": "クラスを削除できません",
+ "minClassesDesc": "分類モデルには少なくとも 2 つのクラスが必要です。別のクラスを追加してから削除してください。"
+ },
+ "deleteModel": {
+ "title": "分類モデルを削除",
+ "single": "{{name}} を削除してもよろしいですか?画像や学習データを含むすべての関連データが完全に削除され、この操作は元に戻せません。",
+ "desc_other": "{{count}} 件のモデルを削除してもよろしいですか?関連するすべてのデータが完全に削除され、この操作は元に戻せません。"
+ },
+ "edit": {
+ "title": "分類モデルを編集",
+ "descriptionState": "この状態分類モデルのクラスを編集します。変更を反映するにはモデルの再学習が必要です。",
+ "descriptionObject": "このオブジェクト分類モデルのオブジェクトタイプおよび分類タイプを編集します。",
+ "stateClassesInfo": "注意: 状態クラスを変更すると、更新後のクラスでモデルを再学習する必要があります。"
+ },
+ "deleteDatasetImages": {
+ "title": "データセット画像を削除",
+ "desc_other": "{{dataset}} から {{count}} 枚の画像を削除してもよろしいですか?この操作は元に戻せず、モデルの再学習が必要になります。"
+ },
+ "deleteTrainImages": {
+ "title": "学習用画像を削除",
+ "desc_other": "{{count}} 枚の画像を削除してもよろしいですか?この操作は元に戻すことができません。"
+ },
+ "renameCategory": {
+ "title": "クラス名を変更",
+ "desc": "{{name}} の新しい名前を入力してください。変更を有効にするにはモデルの再学習が必要です。"
+ },
+ "description": {
+ "invalidName": "無効な名前です。使用できるのは、英数字、空白、アポストロフィ、アンダースコア、ハイフンのみです。"
+ },
+ "categories": "クラス",
+ "createCategory": {
+ "new": "新しいクラスを作成"
+ },
+ "categorizeImageAs": "画像を次として分類:",
+ "categorizeImage": "画像を分類",
+ "menu": {
+ "objects": "オブジェクト",
+ "states": "状態"
+ },
+ "noModels": {
+ "object": {
+ "title": "オブジェクト分類モデルがありません",
+ "description": "検出されたオブジェクトを分類するためのカスタムモデルを作成します。",
+ "buttonText": "オブジェクトモデルを作成"
+ },
+ "state": {
+ "title": "状態分類モデルがありません",
+ "description": "特定のカメラ領域の状態変化を監視・分類するためのカスタムモデルを作成します。",
+ "buttonText": "状態モデルを作成"
+ }
+ }
+}
diff --git a/web/public/locales/ja/views/configEditor.json b/web/public/locales/ja/views/configEditor.json
index b3d523c94..704c83d0a 100644
--- a/web/public/locales/ja/views/configEditor.json
+++ b/web/public/locales/ja/views/configEditor.json
@@ -1,7 +1,18 @@
{
"copyConfig": "設定をコピー",
- "configEditor": "Configエディタ",
+ "configEditor": "設定エディタ",
"saveAndRestart": "保存後再起動",
"saveOnly": "保存",
- "confirm": "保存せずに終了しますか?"
+ "confirm": "保存せずに終了しますか?",
+ "documentTitle": "設定エディタ - Frigate",
+ "safeConfigEditor": "設定エディタ (セーフモード)",
+ "safeModeDescription": "Frigate は config の検証エラーによるセーフモードです.",
+ "toast": {
+ "success": {
+ "copyToClipboard": "コンフィグをクリップボードにコピー。"
+ },
+ "error": {
+ "savingError": "設定の保存に失敗しました"
+ }
+ }
}
diff --git a/web/public/locales/ja/views/events.json b/web/public/locales/ja/views/events.json
index f8ac7549c..544412974 100644
--- a/web/public/locales/ja/views/events.json
+++ b/web/public/locales/ja/views/events.json
@@ -1,7 +1,67 @@
{
"detections": "検出",
"motion": {
- "label": "動作"
+ "label": "モーション",
+ "only": "モーションのみ"
},
- "alerts": "アラート"
+ "alerts": "アラート",
+ "empty": {
+ "detection": "レビューする検出はありません",
+ "alert": "レビューするアラートはありません",
+ "motion": "モーションデータは見つかりません",
+ "recordingsDisabled": {
+ "title": "録画を有効にする必要があります",
+ "description": "カメラの録画が有効になっている場合にのみ、そのカメラに対してレビューアイテムを作成できます。"
+ }
+ },
+ "camera": "カメラ",
+ "allCameras": "全カメラ",
+ "timeline": "タイムライン",
+ "timeline.aria": "タイムラインを選択",
+ "events": {
+ "label": "イベント",
+ "aria": "イベントを選択",
+ "noFoundForTimePeriod": "この期間のイベントは見つかりません。"
+ },
+ "documentTitle": "レビュー - Frigate",
+ "recordings": {
+ "documentTitle": "録画 - Frigate"
+ },
+ "calendarFilter": {
+ "last24Hours": "直近24時間"
+ },
+ "markAsReviewed": "レビュー済みにする",
+ "markTheseItemsAsReviewed": "これらの項目をレビュー済みにする",
+ "newReviewItems": {
+ "label": "新しいレビュー項目を表示",
+ "button": "レビューすべき新規項目"
+ },
+ "selected_one": "{{count}} 件選択",
+ "selected_other": "{{count}} 件選択",
+ "detected": "検出",
+ "suspiciousActivity": "不審なアクティビティ",
+ "threateningActivity": "脅威となるアクティビティ",
+ "zoomIn": "ズームイン",
+ "zoomOut": "ズームアウト",
+ "detail": {
+ "label": "詳細",
+ "noDataFound": "確認する詳細データはありません",
+ "aria": "詳細表示を切り替え",
+ "trackedObject_one": "{{count}} 件のオブジェクト",
+ "trackedObject_other": "{{count}} 件のオブジェクト",
+ "noObjectDetailData": "オブジェクトの詳細データがありません。",
+ "settings": "詳細表示設定",
+ "alwaysExpandActive": {
+ "title": "アクティブ項目を常に展開",
+ "desc": "利用可能な場合、アクティブなレビュー項目のオブジェクト詳細を常に展開する。"
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "追跡ポイント",
+ "clickToSeek": "クリックしてこの時点に移動"
+ },
+ "select_all": "すべて",
+ "normalActivity": "通常",
+ "needsReview": "要確認",
+ "securityConcern": "セキュリティ上の懸念"
}
diff --git a/web/public/locales/ja/views/explore.json b/web/public/locales/ja/views/explore.json
index 0dec7d0b9..35265cc50 100644
--- a/web/public/locales/ja/views/explore.json
+++ b/web/public/locales/ja/views/explore.json
@@ -1,3 +1,299 @@
{
- "generativeAI": "生成AI"
+ "generativeAI": "生成AI",
+ "documentTitle": "探索 - Frigate",
+ "details": {
+ "timestamp": "タイムスタンプ",
+ "item": {
+ "title": "レビュー項目の詳細",
+ "desc": "レビュー項目の詳細",
+ "button": {
+ "share": "このレビュー項目を共有",
+ "viewInExplore": "探索で表示"
+ },
+ "tips": {
+ "mismatch_other": "利用不可のオブジェクトが {{count}} 件、このレビュー項目に含まれています。これらはアラートまたは検出の条件を満たしていないか、既にクリーンアップ/削除されています。",
+ "hasMissingObjects": "次のラベルの追跡オブジェクトを保存したい場合は設定を調整してください: {{objects}}"
+ },
+ "toast": {
+ "success": {
+ "regenerate": "{{provider}} に新しい説明をリクエストしました。プロバイダの速度により再生成に時間がかかる場合があります。",
+ "updatedSublabel": "サブラベルを更新しました。",
+ "updatedLPR": "ナンバープレートを更新しました。",
+ "audioTranscription": "音声文字起こしのリクエストは正常に送信されました。Frigate サーバーの処理速度によっては、文字起こしの完了までにしばらく時間がかかる場合があります。",
+ "updatedAttributes": "属性が正常に更新されました。"
+ },
+ "error": {
+ "regenerate": "{{provider}} への新しい説明の呼び出しに失敗しました: {{errorMessage}}",
+ "updatedSublabelFailed": "サブラベルの更新に失敗しました: {{errorMessage}}",
+ "updatedLPRFailed": "ナンバープレートの更新に失敗しました: {{errorMessage}}",
+ "audioTranscription": "音声文字起こしのリクエストに失敗しました: {{errorMessage}}",
+ "updatedAttributesFailed": "属性の更新に失敗しました: {{errorMessage}}"
+ }
+ }
+ },
+ "label": "ラベル",
+ "editSubLabel": {
+ "title": "サブラベルを編集",
+ "desc": "この {{label}} の新しいサブラベルを入力",
+ "descNoLabel": "この追跡オブジェクトの新しいサブラベルを入力"
+ },
+ "editLPR": {
+ "title": "ナンバープレートを編集",
+ "desc": "この {{label}} の新しいナンバープレート値を入力",
+ "descNoLabel": "この追跡オブジェクトの新しいナンバープレート値を入力"
+ },
+ "snapshotScore": {
+ "label": "スナップショットスコア"
+ },
+ "topScore": {
+ "label": "トップスコア",
+ "info": "トップスコアは追跡オブジェクトの最高中央値スコアであり、検索結果のサムネイルに表示されるスコアとは異なる場合があります。"
+ },
+ "score": {
+ "label": "スコア"
+ },
+ "recognizedLicensePlate": "認識されたナンバープレート",
+ "estimatedSpeed": "推定速度",
+ "objects": "オブジェクト",
+ "camera": "カメラ",
+ "zones": "ゾーン",
+ "button": {
+ "findSimilar": "類似を検索",
+ "regenerate": {
+ "title": "再生成",
+ "label": "追跡オブジェクトの説明を再生成"
+ }
+ },
+ "description": {
+ "label": "説明",
+ "placeholder": "追跡オブジェクトの説明",
+ "aiTips": "追跡オブジェクトのライフサイクルが終了するまで、生成AIプロバイダに説明はリクエストされません。"
+ },
+ "expandRegenerationMenu": "再生成メニューを展開",
+ "regenerateFromSnapshot": "スナップショットから再生成",
+ "regenerateFromThumbnails": "サムネイルから再生成",
+ "tips": {
+ "descriptionSaved": "説明を保存しました",
+ "saveDescriptionFailed": "説明の更新に失敗しました: {{errorMessage}}"
+ },
+ "editAttributes": {
+ "title": "属性を編集",
+ "desc": "この {{label}} の分類属性を選択してください"
+ },
+ "attributes": "分類属性",
+ "title": {
+ "label": "タイトル"
+ }
+ },
+ "exploreMore": "{{label}} のオブジェクトをさらに探索",
+ "exploreIsUnavailable": {
+ "title": "探索は利用できません",
+ "embeddingsReindexing": {
+ "context": "追跡オブジェクトの埋め込みの再インデックスが完了すると「探索」を使用できます。",
+ "startingUp": "起動中…",
+ "estimatedTime": "残りの推定時間:",
+ "finishingShortly": "まもなく完了",
+ "step": {
+ "thumbnailsEmbedded": "埋め込み済みサムネイル: ",
+ "descriptionsEmbedded": "埋め込み済み説明: ",
+ "trackedObjectsProcessed": "処理済み追跡オブジェクト: "
+ }
+ },
+ "downloadingModels": {
+ "context": "Frigate はセマンティック検索(意味理解型画像検索)をサポートするために必要な埋め込みモデルをダウンロードしています。ネットワーク速度により数分かかる場合があります。",
+ "setup": {
+ "visionModel": "ビジョンモデル",
+ "visionModelFeatureExtractor": "ビジョンモデル特徴抽出器",
+ "textModel": "テキストモデル",
+ "textTokenizer": "テキストトークナイザー"
+ },
+ "tips": {
+ "context": "モデルのダウンロード後、追跡オブジェクトの埋め込みを再インデックスすることを検討してください。"
+ },
+ "error": "エラーが発生しました。Frigate のログを確認してください。"
+ }
+ },
+ "trackedObjectDetails": "追跡オブジェクトの詳細",
+ "type": {
+ "details": "詳細",
+ "snapshot": "スナップショット",
+ "video": "動画",
+ "object_lifecycle": "オブジェクトのライフサイクル",
+ "thumbnail": "サムネイル",
+ "tracking_details": "追跡詳細"
+ },
+ "objectLifecycle": {
+ "title": "オブジェクトのライフサイクル",
+ "noImageFound": "このタイムスタンプの画像は見つかりません。",
+ "createObjectMask": "オブジェクトマスクを作成",
+ "adjustAnnotationSettings": "アノテーション設定を調整",
+ "scrollViewTips": "スクロールしてこのオブジェクトのライフサイクルの重要な瞬間を表示します。",
+ "autoTrackingTips": "オートトラッキングカメラではバウンディングボックスの位置が正確でない場合があります。",
+ "count": "{{first}} / {{second}}",
+ "trackedPoint": "追跡ポイント",
+ "lifecycleItemDesc": {
+ "visible": "{{label}} を検出",
+ "entered_zone": "{{label}} が {{zones}} に進入",
+ "active": "{{label}} がアクティブになりました",
+ "stationary": "{{label}} が静止しました",
+ "attribute": {
+ "faceOrLicense_plate": "{{label}} の {{attribute}} を検出",
+ "other": "{{label}} を {{attribute}} として認識"
+ },
+ "gone": "{{label}} が離脱",
+ "heard": "{{label}} を検知(音声)",
+ "external": "{{label}} を検出",
+ "header": {
+ "zones": "ゾーン",
+ "ratio": "比率",
+ "area": "面積"
+ }
+ },
+ "annotationSettings": {
+ "title": "アノテーション設定",
+ "showAllZones": {
+ "title": "すべてのゾーンを表示",
+ "desc": "オブジェクトがゾーンに入ったフレームでは常にゾーンを表示します。"
+ },
+ "offset": {
+ "label": "アノテーションオフセット",
+ "desc": "このデータはカメラの detect フィードから来ていますが、record フィードの画像に重ねて表示されます。2つのストリームが完全に同期していない可能性があるため、バウンディングボックスと映像が完全には一致しないことがあります。annotation_offset フィールドで調整できます。",
+ "millisecondsToOffset": "detect のアノテーションをオフセットするミリ秒数。既定: 0",
+ "tips": "ヒント: 左から右へ歩く人物のイベントクリップを想像してください。タイムラインのバウンディングボックスが人物より常に左側にあるなら値を小さく、常に先行しているなら値を大きくします。",
+ "toast": {
+ "success": "{{camera}} のアノテーションオフセットを設定ファイルに保存しました。変更を適用するには Frigate を再起動してください。"
+ }
+ }
+ },
+ "carousel": {
+ "previous": "前のスライド",
+ "next": "次のスライド"
+ }
+ },
+ "itemMenu": {
+ "downloadVideo": {
+ "label": "動画をダウンロード",
+ "aria": "動画をダウンロード"
+ },
+ "downloadSnapshot": {
+ "label": "スナップショットをダウンロード",
+ "aria": "スナップショットをダウンロード"
+ },
+ "viewObjectLifecycle": {
+ "label": "オブジェクトのライフサイクルを表示",
+ "aria": "オブジェクトのライフサイクルを表示"
+ },
+ "findSimilar": {
+ "label": "類似を検索",
+ "aria": "類似する追跡オブジェクトを検索"
+ },
+ "addTrigger": {
+ "label": "トリガーを追加",
+ "aria": "この追跡オブジェクトのトリガーを追加"
+ },
+ "audioTranscription": {
+ "label": "文字起こし",
+ "aria": "音声文字起こしをリクエスト"
+ },
+ "submitToPlus": {
+ "label": "Frigate+ に送信",
+ "aria": "Frigate Plus に送信"
+ },
+ "viewInHistory": {
+ "label": "履歴で表示",
+ "aria": "履歴で表示"
+ },
+ "deleteTrackedObject": {
+ "label": "この追跡オブジェクトを削除"
+ },
+ "downloadCleanSnapshot": {
+ "label": "クリーンなスナップショットをダウンロード",
+ "aria": "クリーンなスナップショットをダウンロード"
+ },
+ "viewTrackingDetails": {
+ "label": "追跡詳細を表示",
+ "aria": "追跡詳細を表示"
+ },
+ "showObjectDetails": {
+ "label": "オブジェクトの移動経路を表示"
+ },
+ "hideObjectDetails": {
+ "label": "オブジェクトの移動経路を非表示"
+ }
+ },
+ "dialog": {
+ "confirmDelete": {
+ "title": "削除の確認",
+ "desc": "この追跡オブジェクトを削除すると、スナップショット、保存された埋め込み、および関連する追跡詳細項目が削除されます。履歴ビューの録画映像は削除されません。mode: {{effectiveRetainMode}} になっているため、このオンデマンド録画では {{effectiveRetainModeName}} を含むセグメントのみが保持されます。"
+ },
+ "editLayout": {
+ "label": "レイアウトを編集",
+ "group": {
+ "label": "カメラグループを編集"
+ },
+ "exitEdit": "編集を終了"
+ },
+ "noCameras": {
+ "title": "カメラが設定されていません",
+ "buttonText": "カメラを追加",
+ "description": "開始するには、Frigateにカメラを接続してください。",
+ "restricted": {
+ "title": "利用可能なカメラがありません",
+ "description": "このグループ内のカメラを表示する権限がありません。"
+ },
+ "default": {
+ "title": "設定済みのカメラがありません",
+ "description": "Frigate にカメラを接続して開始しましょう。",
+ "buttonText": "カメラを追加"
+ },
+ "group": {
+ "title": "このグループにカメラがありません",
+ "description": "このカメラグループには、割り当て済みまたは有効なカメラがありません。",
+ "buttonText": "グループを管理"
+ }
+ },
+ "snapshot": {
+ "takeSnapshot": "即時スナップショットをダウンロード",
+ "noVideoSource": "スナップショットに使用できる映像ソースがありません。",
+ "captureFailed": "スナップショットの取得に失敗しました。",
+ "downloadStarted": "スナップショットのダウンロードを開始しました。"
+ }
}
diff --git a/web/public/locales/ja/views/recording.json b/web/public/locales/ja/views/recording.json
index 336551285..7d76d191f 100644
--- a/web/public/locales/ja/views/recording.json
+++ b/web/public/locales/ja/views/recording.json
@@ -1,5 +1,12 @@
{
- "filter": "フィルタ",
+ "filter": "フィルター",
"calendar": "カレンダー",
- "export": "エクスポート"
+ "export": "書き出し",
+ "filters": "フィルター",
+ "toast": {
+ "error": {
+ "noValidTimeSelected": "適切な時刻の範囲が選択されていません",
+ "endTimeMustAfterStartTime": "終了時刻は開始時刻より後である必要があります"
+ }
+ }
}
diff --git a/web/public/locales/ja/views/search.json b/web/public/locales/ja/views/search.json
index 02f285695..540606c83 100644
--- a/web/public/locales/ja/views/search.json
+++ b/web/public/locales/ja/views/search.json
@@ -1,11 +1,73 @@
{
- "searchFor": "{{inputValue}} を検索",
+ "searchFor": "「{{inputValue}}」を検索",
"button": {
"save": "検索を保存",
- "delete": "保存した検索を削除",
- "filterInformation": "フィルタ情報",
- "clear": "検索をクリア"
+ "delete": "保存済み検索を削除",
+ "filterInformation": "フィルター情報",
+ "clear": "検索をクリア",
+ "filterActive": "フィルターが有効"
},
"search": "検索",
- "savedSearches": "保存した検索"
+ "savedSearches": "保存済み検索",
+ "trackedObjectId": "追跡オブジェクトID",
+ "filter": {
+ "label": {
+ "cameras": "カメラ",
+ "labels": "ラベル",
+ "zones": "ゾーン",
+ "sub_labels": "サブラベル",
+ "search_type": "検索タイプ",
+ "time_range": "期間",
+ "before": "以前",
+ "after": "以後",
+ "min_score": "最小スコア",
+ "max_score": "最大スコア",
+ "min_speed": "最小速度",
+ "max_speed": "最大速度",
+ "recognized_license_plate": "認識されたナンバープレート",
+ "has_clip": "クリップあり",
+ "has_snapshot": "スナップショットあり",
+ "attributes": "属性"
+ },
+ "searchType": {
+ "thumbnail": "サムネイル",
+ "description": "説明"
+ },
+ "toast": {
+ "error": {
+ "beforeDateBeLaterAfter": "「以前」日付は「以後」日付より後である必要があります。",
+ "afterDatebeEarlierBefore": "「以後」日付は「以前」日付より前である必要があります。",
+ "minScoreMustBeLessOrEqualMaxScore": "「最小スコア」は「最大スコア」以下である必要があります。",
+ "maxScoreMustBeGreaterOrEqualMinScore": "「最大スコア」は「最小スコア」以上である必要があります。",
+ "minSpeedMustBeLessOrEqualMaxSpeed": "「最小速度」は「最大速度」以下である必要があります。",
+ "maxSpeedMustBeGreaterOrEqualMinSpeed": "「最大速度」は「最小速度」以上である必要があります。"
+ }
+ },
+ "tips": {
+ "title": "テキストフィルターの使い方",
+ "desc": {
+ "text": "フィルターを使うと検索結果を絞り込めます。入力欄での使い方は次の通りです。",
+ "step1": "フィルターのキー名の後にコロンを付けて入力します(例: \"cameras:\")。",
+ "step2": "候補から値を選ぶか、自分で入力します。",
+ "step3": "複数のフィルターは、間にスペースを入れて続けて追加できます。",
+ "step4": "日付フィルター(before: と after:)は {{DateFormat}} 形式を使用します。",
+ "step5": "期間フィルターは {{exampleTime}} 形式を使用します。",
+ "step6": "フィルターは隣の 'x' をクリックして削除できます。",
+ "exampleLabel": "例:"
+ }
+ },
+ "header": {
+ "currentFilterType": "フィルター値",
+ "noFilters": "フィルター",
+ "activeFilters": "有効なフィルター"
+ }
+ },
+ "similaritySearch": {
+ "title": "類似検索",
+ "active": "類似検索を実行中",
+ "clear": "類似検索をクリア"
+ },
+ "placeholder": {
+ "search": "検索…"
+ }
}
diff --git a/web/public/locales/ja/views/settings.json b/web/public/locales/ja/views/settings.json
index f0993c869..5c36b1919 100644
--- a/web/public/locales/ja/views/settings.json
+++ b/web/public/locales/ja/views/settings.json
@@ -1,7 +1,1221 @@
{
"documentTitle": {
"authentication": "認証設定 - Frigate",
- "camera": "カメラの設定 - Frigate",
- "default": "設定 - Frigate"
+ "camera": "カメラ設定 - Frigate",
+ "default": "設定 - Frigate",
+ "enrichments": "高度解析設定 - Frigate",
+ "masksAndZones": "マスク/ゾーンエディタ - Frigate",
+ "motionTuner": "モーションチューナー - Frigate",
+ "object": "デバッグ - Frigate",
+ "general": "UI設定 - Frigate",
+ "frigatePlus": "Frigate+ 設定 - Frigate",
+ "notifications": "通知設定 - Frigate",
+ "cameraManagement": "カメラ設定 - Frigate",
+ "cameraReview": "カメラレビュー設定 - Frigate"
+ },
+ "menu": {
+ "ui": "UI",
+ "enrichments": "高度解析",
+ "cameras": "カメラ設定",
+ "masksAndZones": "マスク/ゾーン",
+ "motionTuner": "モーションチューナー",
+ "triggers": "トリガー",
+ "debug": "デバッグ",
+ "users": "ユーザー",
+ "notifications": "通知",
+ "frigateplus": "Frigate+",
+ "cameraManagement": "管理",
+ "cameraReview": "レビュー",
+ "roles": "区分"
+ },
+ "dialog": {
+ "unsavedChanges": {
+ "title": "未保存の変更があります。",
+ "desc": "続行する前に変更を保存しますか?"
+ }
+ },
+ "cameraSetting": {
+ "camera": "カメラ",
+ "noCamera": "カメラなし"
+ },
+ "general": {
+ "title": "UI設定",
+ "liveDashboard": {
+ "title": "ライブダッシュボード",
+ "automaticLiveView": {
+ "label": "自動ライブビュー",
+ "desc": "アクティビティ検知時に自動でそのカメラのライブビューへ切り替えます。無効にすると、ライブダッシュボード上の静止画像は1分に1回のみ更新されます。"
+ },
+ "playAlertVideos": {
+ "label": "アラート動画を再生",
+ "desc": "既定では、ライブダッシュボードの最近のアラートは小さなループ動画として再生されます。無効にすると、最近のアラートはこのデバイス/ブラウザでは静止画像のみ表示されます。"
+ },
+ "displayCameraNames": {
+ "label": "常にカメラ名を表示",
+ "desc": "マルチカメラのライブビュー ダッシュボードで、カメラ名を常にチップ表示します。"
+ },
+ "liveFallbackTimeout": {
+ "label": "ライブプレイヤーのフォールバック タイムアウト",
+ "desc": "カメラの高画質ライブストリームが利用できない場合、指定した秒数後に低帯域モードへ切り替えます。デフォルト:3 秒"
+ }
+ },
+ "storedLayouts": {
+ "title": "保存済みレイアウト",
+ "desc": "カメラグループ内のレイアウトはドラッグ/リサイズできます。位置情報はブラウザのローカルストレージに保存されます。",
+ "clearAll": "すべてのレイアウトをクリア"
+ },
+ "cameraGroupStreaming": {
+ "title": "カメラグループのストリーミング設定",
+ "desc": "各カメラグループのストリーミング設定はブラウザのローカルストレージに保存されます。",
+ "clearAll": "すべてのストリーミング設定をクリア"
+ },
+ "recordingsViewer": {
+ "title": "録画ビューア",
+ "defaultPlaybackRate": {
+ "label": "既定の再生速度",
+ "desc": "録画再生の既定の再生速度です。"
+ }
+ },
+ "calendar": {
+ "title": "カレンダー",
+ "firstWeekday": {
+ "label": "週の開始曜日",
+ "desc": "レビューカレンダーで週が始まる曜日。",
+ "sunday": "日曜日",
+ "monday": "月曜日"
+ }
+ },
+ "toast": {
+ "success": {
+ "clearStoredLayout": "{{cameraName}} の保存済みレイアウトをクリアしました",
+ "clearStreamingSettings": "すべてのカメラグループのストリーミング設定をクリアしました。"
+ },
+ "error": {
+ "clearStoredLayoutFailed": "保存済みレイアウトのクリアに失敗しました: {{errorMessage}}",
+ "clearStreamingSettingsFailed": "ストリーミング設定のクリアに失敗しました: {{errorMessage}}"
+ }
+ }
+ },
+ "enrichments": {
+ "title": "高度解析設定",
+ "unsavedChanges": "未保存の高度解析設定の変更",
+ "birdClassification": {
+ "title": "鳥類分類",
+ "desc": "量子化された TensorFlow モデルを使って既知の鳥を識別します。既知の鳥を認識した場合、その一般名を sub_label として追加します。この情報は UI、フィルタ、通知に含まれます。"
+ },
+ "semanticSearch": {
+ "title": "セマンティック検索",
+ "desc": "Frigate のセマンティック検索では、画像そのもの、ユーザー定義のテキスト説明、または自動生成された説明を用いて、レビュー項目内の追跡オブジェクトを検索できます。",
+ "reindexNow": {
+ "label": "今すぐ再インデックス",
+ "desc": "再インデックスは、すべての追跡オブジェクトの埋め込みを再生成します。バックグラウンドで実行され、追跡オブジェクト数によっては CPU を使い切り、相応の時間がかかる場合があります。",
+ "confirmTitle": "再インデックスの確認",
+ "confirmDesc": "すべての追跡オブジェクトの埋め込みを再インデックスしますか?この処理はバックグラウンドで実行されますが、CPU を使い切り、時間がかかる場合があります。進行状況は[探索]ページで確認できます。",
+ "confirmButton": "再インデックス",
+ "success": "再インデックスを開始しました。",
+ "alreadyInProgress": "再インデックスはすでに進行中です。",
+ "error": "再インデックスの開始に失敗しました: {{errorMessage}}"
+ },
+ "modelSize": {
+ "label": "モデルサイズ",
+ "desc": "セマンティック検索の埋め込みに使用するモデルのサイズです。",
+ "small": {
+ "title": "スモール",
+ "desc": "small を使用すると、量子化モデルにより RAM 使用量が少なく、CPU 上で高速に動作します。埋め込み品質の差はごく僅かです。"
+ },
+ "large": {
+ "title": "ラージ",
+ "desc": "large を使用すると、完全な Jina モデルを用い、可能であれば自動的に GPU で動作します。"
+ }
+ }
+ },
+ "faceRecognition": {
+ "title": "顔認識",
+ "desc": "顔認識により、人に名前を割り当て、顔を認識した際にその人名をサブラベルとして付与します。この情報は UI、フィルタ、通知に含まれます。",
+ "modelSize": {
+ "label": "モデルサイズ",
+ "desc": "顔認識に使用するモデルのサイズです。",
+ "small": {
+ "title": "スモール",
+ "desc": "small は FaceNet ベースの顔埋め込みモデルを使用し、多くの CPU で効率よく動作します。"
+ },
+ "large": {
+ "title": "ラージ",
+ "desc": "large は ArcFace ベースの顔埋め込みモデルを使用し、可能であれば自動的に GPU で動作します。"
+ }
+ }
+ },
+ "licensePlateRecognition": {
+ "title": "ナンバープレート認識",
+ "desc": "車両のナンバープレートを認識し、検出文字列を recognized_license_plate フィールドへ、または既知の名称を car タイプのオブジェクトの sub_label として自動追加できます。一般的な用途として、私道に入ってくる車や道路を通過する車のナンバー読み取りがあります。"
+ },
+ "restart_required": "再起動が必要です(高度解析設定を変更)",
+ "toast": {
+ "success": "高度解析設定を保存しました。変更を適用するには Frigate を再起動してください。",
+ "error": "設定変更の保存に失敗しました: {{errorMessage}}"
+ }
+ },
+ "camera": {
+ "title": "カメラ設定",
+ "streams": {
+ "title": "ストリーム",
+ "desc": "Frigate の再起動まで、カメラを一時的に無効化します。無効化すると、このカメラのストリーム処理は完全に停止します。検出、録画、デバッグは利用できません。モーションボックス
現在モーションが検出されている領域に赤いボックスが重ねて表示されます
" + }, + "regions": { + "title": "領域", + "desc": "物体検出器へ送られる関心領域のボックスを表示します", + "tips": "領域ボックス
物体検出器へ送られるフレーム内の関心領域に明るい緑のボックスが重ねて表示されます。
" + }, + "paths": { + "title": "軌跡", + "desc": "追跡オブジェクトの重要ポイントを表示します", + "tips": "軌跡
線や円で、オブジェクトのライフサイクル中に移動した重要ポイントを示します。
" + }, + "objectShapeFilterDrawing": { + "title": "オブジェクト形状フィルタの作図", + "desc": "画像上に矩形を描いて面積と比率の詳細を表示します", + "tips": "このオプションを有効にすると、カメラ画像上に矩形を描いてその面積と比率を表示できます。これらの値は設定ファイルのオブジェクト形状フィルタのパラメータ設定に利用できます。", + "score": "スコア", + "ratio": "比率", + "area": "面積" + } + }, + "users": { + "title": "ユーザー", + "management": { + "title": "ユーザー管理", + "desc": "この Frigate インスタンスのユーザーアカウントを管理します。" + }, + "addUser": "ユーザーを追加", + "updatePassword": "パスワードをリセット", + "toast": { + "success": { + "createUser": "ユーザー {{user}} を作成しました", + "deleteUser": "ユーザー {{user}} を削除しました", + "updatePassword": "パスワードを更新しました。", + "roleUpdated": "{{user}} のロールを更新しました" + }, + "error": { + "setPasswordFailed": "パスワードの保存に失敗しました: {{errorMessage}}", + "createUserFailed": "ユーザーの作成に失敗しました: {{errorMessage}}", + "deleteUserFailed": "ユーザーの削除に失敗しました: {{errorMessage}}", + "roleUpdateFailed": "ロールの更新に失敗しました: {{errorMessage}}" + } + }, + "table": { + "username": "ユーザー名", + "actions": "操作", + "role": "ロール", + "noUsers": "ユーザーが見つかりません。", + "changeRole": "ユーザーロールを変更", + "password": "パスワードをリセット", + "deleteUser": "ユーザーを削除" + }, + "dialog": { + "form": { + "user": { + "title": "ユーザー名", + "desc": "使用できるのは英数字、ピリオド、アンダースコアのみです。", + "placeholder": "ユーザー名を入力" + }, + "password": { + "title": "パスワード", + "placeholder": "パスワードを入力", + "confirm": { + "title": "パスワードの確認", + "placeholder": "パスワードを再入力" + }, + "strength": { + "title": "パスワード強度: ", + "weak": "弱い", + "medium": "普通", + "strong": "強い", + "veryStrong": "非常に強い" + }, + "match": "パスワードが一致しています", + "notMatch": "パスワードが一致しません", + "show": "パスワードを表示", + "hide": "パスワードを非表示", + "requirements": { + "title": "パスワード要件:", + "length": "8 文字以上", + "uppercase": "大文字を 1 文字以上含める", + "digit": "数字を 1 文字以上含める", + "special": "少なくとも 1 つの特殊文字(!@#$%^&*(),.?”:{}|<>)が必要です" + } + }, + "newPassword": { + "title": "新しいパスワード", + "placeholder": "新しいパスワードを入力", + "confirm": { + "placeholder": "新しいパスワードを再入力" + } + }, + "usernameIsRequired": "ユーザー名は必須です", + "passwordIsRequired": "パスワードは必須です", + "currentPassword": { + "title": "現在のパスワード", + "placeholder": "現在のパスワードを入力" + } + }, + "createUser": { + "title": "新規ユーザーを作成", + "desc": "新しいユーザーアカウントを追加し、Frigate UI へのアクセスロールを指定します。", + "usernameOnlyInclude": "ユーザー名に使用できるのは英数字、.、_ のみです", + "confirmPassword": "パスワードを確認してください" + }, + "deleteUser": { + "title": "ユーザーを削除", + "desc": "この操作は元に戻せません。ユーザーアカウントおよび関連データは完全に削除されます。", + "warn": "{{username}} を削除してもよろしいですか?" + }, + "passwordSetting": { + "cannotBeEmpty": "パスワードを空にはできません", + "doNotMatch": "パスワードが一致しません", + "updatePassword": "{{username}} のパスワードを更新", + "setPassword": "パスワードを設定", + "desc": "強力なパスワードを作成して、このアカウントを保護してください。", + "currentPasswordRequired": "現在のパスワードは必須です", + "incorrectCurrentPassword": "現在のパスワードが正しくありません", + "passwordVerificationFailed": "パスワードの確認に失敗しました", + "multiDeviceWarning": "他のログイン中のデバイスは {{refresh_time}} 以内に再ログインが必要になります。", + "multiDeviceAdmin": "JWT シークレットをローテーションすることで、すべてのユーザーに即時再認証を強制することもできます。" + }, + "changeRole": { + "title": "ユーザーロールを変更", + "select": "ロールを選択", + "desc": "{{username}} の権限を更新します", + "roleInfo": { + "intro": "このユーザーに適切なロールを選択してください:", + "admin": "管理者", + "adminDesc": "すべての機能にフルアクセス。", + "viewer": "閲覧者", + "viewerDesc": "ライブ、レビュー、探索、書き出しに限定。", + "customDesc": "特定のカメラアクセスを持つカスタムロール。" + } + } + } + }, + "roles": { + "management": { + "title": "閲覧者ロール管理", + "desc": "この Frigate インスタンスのカスタム閲覧者ロールと、そのカメラアクセス権を管理します。" + }, + "addRole": "ロールを追加", + "table": { + "role": "ロール", + "cameras": "カメラ", + "actions": "操作", + "noRoles": "カスタムロールが見つかりません。", + "editCameras": "カメラを編集", + "deleteRole": "ロールを削除" + }, + "toast": { + "success": { + "createRole": "ロール {{role}} を作成しました", + "updateCameras": "ロール {{role}} のカメラを更新しました", + "deleteRole": "ロール {{role}} を削除しました", + "userRolesUpdated_other": "このロールに割り当てられていた {{count}} ユーザーは「viewer」に更新され、すべてのカメラへの閲覧アクセスが付与されました。" + }, + "error": { + "createRoleFailed": "ロールの作成に失敗しました: {{errorMessage}}", + "updateCamerasFailed": "カメラの更新に失敗しました: {{errorMessage}}", + "deleteRoleFailed": "ロールの削除に失敗しました: {{errorMessage}}", + "userUpdateFailed": "ユーザーロールの更新に失敗しました: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "新しいロールを作成", + "desc": "新しいロールを追加し、カメラアクセス権を指定します。" + }, + "editCameras": { + "title": "ロールのカメラを編集", + "desc": "ロール {{role}} のカメラアクセスを更新します。" + }, + "deleteRole": { + "title": "ロールを削除", + "desc": "この操作は元に戻せません。ロールは完全に削除され、このロールを持っていたユーザーは「viewer」ロールに再割り当てされ、すべてのカメラへの閲覧アクセスが付与されます。", + "warn": "{{role}} を削除してもよろしいですか?", + "deleting": "削除中…" + }, + "form": { + "role": { + "title": "ロール名", + "placeholder": "ロール名を入力", + "desc": "使用できるのは英数字、ピリオド、アンダースコアのみです。", + "roleIsRequired": "ロール名は必須です", + "roleOnlyInclude": "ロール名に使用できるのは英数字、.、_ のみです", + "roleExists": "この名前のロールは既に存在します。" + }, + "cameras": { + "title": "カメラ", + "desc": "このロールでアクセス可能なカメラを選択します。少なくとも1台が必要です。", + "required": "少なくとも1台のカメラを選択してください。" + } + } + } + }, + "notification": { + "title": "通知", + "notificationSettings": { + "title": "通知設定", + "desc": "Frigate はブラウザで実行中、または PWA としてインストールされている場合に、端末へネイティブのプッシュ通知を送信できます。" + }, + "notificationUnavailable": { + "title": "通知は利用できません", + "desc": "Web プッシュ通知にはセキュアコンテキスト(https://…)が必要です。これはブラウザの制限です。通知を利用するには、セキュアに Frigate へアクセスしてください。"
+ },
+ "globalSettings": {
+ "title": "グローバル設定",
+ "desc": "登録済みのすべてのデバイスで、特定のカメラの通知を一時停止します。"
+ },
+ "email": {
+ "title": "メール",
+ "placeholder": "例: example@email.com",
+ "desc": "有効なメールが必要です。プッシュサービスに問題がある場合の通知に使用します。"
+ },
+ "cameras": {
+ "title": "カメラ",
+ "noCameras": "利用可能なカメラがありません",
+ "desc": "通知を有効にするカメラを選択します。"
+ },
+ "deviceSpecific": "デバイス固有の設定",
+ "registerDevice": "このデバイスを登録",
+ "unregisterDevice": "このデバイスの登録を解除",
+ "sendTestNotification": "テスト通知を送信",
+ "unsavedRegistrations": "未保存の通知登録",
+ "unsavedChanges": "未保存の通知設定の変更",
+ "active": "通知は有効",
+ "suspended": "通知は一時停止中 {{time}}",
+ "suspendTime": {
+ "suspend": "一時停止",
+ "5minutes": "5分間一時停止",
+ "10minutes": "10分間一時停止",
+ "30minutes": "30分間一時停止",
+ "1hour": "1時間一時停止",
+ "12hours": "12時間一時停止",
+ "24hours": "24時間一時停止",
+ "untilRestart": "再起動まで一時停止"
+ },
+ "cancelSuspension": "一時停止を解除",
+ "toast": {
+ "success": {
+ "registered": "通知の登録に成功しました。通知(テスト通知を含む)を送信するには Frigate の再起動が必要です。",
+ "settingSaved": "通知設定を保存しました。"
+ },
+ "error": {
+ "registerFailed": "通知登録の保存に失敗しました。"
+ }
+ }
+ },
+ "frigatePlus": {
+ "title": "Frigate+ 設定",
+ "apiKey": {
+ "title": "Frigate+ API キー",
+ "validated": "Frigate+ API キーが検出され、検証されました",
+ "notValidated": "Frigate+ API キーが検出されないか、検証されていません",
+ "desc": "Frigate+ API キーは Frigate+ サービスとの統合を有効にします。",
+ "plusLink": "Frigate+ の詳細を読む"
+ },
+ "snapshotConfig": {
+ "title": "スナップショット設定",
+ "desc": "Frigate+ への送信には、設定でスナップショットと clean_copy スナップショットの両方を有効にする必要があります。",
+ "cleanCopyWarning": "一部のカメラではスナップショットは有効ですが、クリーンコピーが無効です。これらのカメラから Frigate+ へ画像を送信するには、スナップショット設定で clean_copy を有効にしてください。",
+ "table": {
+ "camera": "カメラ",
+ "snapshots": "スナップショット",
+ "cleanCopySnapshots": "clean_copy スナップショット"
+ }
+ },
+ "modelInfo": {
+ "title": "モデル情報",
+ "modelType": "モデルタイプ",
+ "trainDate": "学習日",
+ "baseModel": "ベースモデル",
+ "plusModelType": {
+ "baseModel": "ベースモデル",
+ "userModel": "ファインチューニング済み"
+ },
+ "supportedDetectors": "対応検出器",
+ "cameras": "カメラ",
+ "loading": "モデル情報を読み込み中…",
+ "error": "モデル情報の読み込みに失敗しました",
+ "availableModels": "利用可能なモデル",
+ "loadingAvailableModels": "利用可能なモデルを読み込み中…",
+ "modelSelect": "ここで Frigate+ 上の利用可能なモデルを選択できます。現在の検出器構成と互換性のあるモデルのみ選択可能です。"
+ },
+ "unsavedChanges": "未保存の Frigate+ 設定の変更",
+ "restart_required": "再起動が必要です(Frigate+ モデルを変更)",
+ "toast": {
+ "success": "Frigate+ 設定を保存しました。変更を適用するには Frigate を再起動してください。",
+ "error": "設定変更の保存に失敗しました: {{errorMessage}}"
+ }
+ },
+ "triggers": {
+ "documentTitle": "トリガー",
+ "management": {
+ "title": "トリガー",
+ "desc": "{{camera}} のトリガーを管理します。サムネイルタイプでは、選択した追跡オブジェクトに類似するサムネイルでトリガーし、説明タイプでは、指定したテキストに類似する説明でトリガーします。"
+ },
+ "addTrigger": "トリガーを追加",
+ "table": {
+ "name": "名称",
+ "type": "タイプ",
+ "content": "コンテンツ",
+ "threshold": "しきい値",
+ "actions": "操作",
+ "noTriggers": "このカメラに設定されたトリガーはありません。",
+ "edit": "編集",
+ "deleteTrigger": "トリガーを削除",
+ "lastTriggered": "最終トリガー時刻"
+ },
+ "type": {
+ "thumbnail": "サムネイル",
+ "description": "説明"
+ },
+ "actions": {
+ "alert": "アラートとしてマーク",
+ "notification": "通知を送信",
+ "sub_label": "サブラベルを追加",
+ "attribute": "属性を追加"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "トリガーを作成",
+ "desc": "カメラ {{camera}} のトリガーを作成します"
+ },
+ "editTrigger": {
+ "title": "トリガーを編集",
+ "desc": "カメラ {{camera}} のトリガー設定を編集します"
+ },
+ "deleteTrigger": {
+ "title": "トリガーを削除",
+ "desc": "トリガー {{triggerName}} を削除してもよろしいですか?この操作は元に戻せません。"
+ },
+ "form": {
+ "name": {
+ "title": "名称",
+ "placeholder": "トリガー名を入力",
+ "error": {
+ "minLength": "この項目は2文字以上で入力してください。",
+ "invalidCharacters": "このフィールドに使用できるのは英数字、アンダースコア、ハイフンのみです。",
+ "alreadyExists": "このカメラには同名のトリガーが既に存在します。"
+ },
+ "description": "このトリガーを識別するための一意の名前または説明を入力してください"
+ },
+ "enabled": {
+ "description": "このトリガーを有効/無効にする"
+ },
+ "type": {
+ "title": "タイプ",
+ "placeholder": "トリガータイプを選択",
+ "description": "類似した追跡オブジェクトの説明が検出されたときにトリガー",
+ "thumbnail": "類似した追跡オブジェクトのサムネイルが検出されたときにトリガー"
+ },
+ "content": {
+ "title": "コンテンツ",
+ "imagePlaceholder": "サムネイルを選択",
+ "textPlaceholder": "テキストを入力",
+ "imageDesc": "最新のサムネイル100件のみが表示されます。目的のサムネイルが見つからない場合は、探索で過去のオブジェクトを確認し、そこのメニューからトリガーを設定してください。",
+ "textDesc": "類似する追跡オブジェクトの説明が検出されたときにこのアクションをトリガーするためのテキストを入力します。",
+ "error": {
+ "required": "コンテンツは必須です。"
+ }
+ },
+ "threshold": {
+ "title": "しきい値",
+ "error": {
+ "min": "しきい値は 0 以上である必要があります",
+ "max": "しきい値は 1 以下である必要があります"
+ },
+ "desc": "このトリガーの類似度しきい値を設定します。値が高いほど、より近い一致が必要になります。"
+ },
+ "actions": {
+ "title": "アクション",
+ "desc": "デフォルトでは、Frigate はすべてのトリガーに対して MQTT メッセージを送信します。サブラベルは、トリガー名をオブジェクトのラベルに追加します。属性(Attributes)は、追跡オブジェクトのメタデータとは別に保存される検索可能なメタデータです。",
+ "error": {
+ "min": "少なくとも1つのアクションを選択してください。"
+ }
+ },
+ "friendly_name": {
+ "title": "表示名",
+ "placeholder": "このトリガーの名前または説明",
+ "description": "このトリガーの表示名または説明文"
+ }
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "トリガー {{name}} を作成しました。",
+ "updateTrigger": "トリガー {{name}} を更新しました。",
+ "deleteTrigger": "トリガー {{name}} を削除しました。"
+ },
+ "error": {
+ "createTriggerFailed": "トリガーの作成に失敗しました: {{errorMessage}}",
+ "updateTriggerFailed": "トリガーの更新に失敗しました: {{errorMessage}}",
+ "deleteTriggerFailed": "トリガーの削除に失敗しました: {{errorMessage}}"
+ }
+ },
+ "semanticSearch": {
+ "desc": "トリガーを使用するにはセマンティック検索を有効にする必要があります。",
+ "title": "セマンティック検索が無効です"
+ },
+ "wizard": {
+ "title": "トリガーを作成",
+ "step1": {
+ "description": "トリガーの基本設定を構成します。"
+ },
+ "step2": {
+ "description": "このアクションをトリガーする内容を設定します。"
+ },
+ "step3": {
+ "description": "このトリガーのしきい値とアクションを設定します。"
+ },
+ "steps": {
+ "nameAndType": "名前と種類",
+ "configureData": "データを設定",
+ "thresholdAndActions": "しきい値とアクション"
+ }
+ }
+ },
+ "cameraWizard": {
+ "step3": {
+ "saveAndApply": "新しいカメラを保存",
+ "description": "カメラのストリームの役割を設定し、必要に応じてストリームを追加します。",
+ "validationTitle": "ストリーム検証",
+ "connectAllStreams": "すべてのストリームを接続",
+ "reconnectionSuccess": "再接続に成功しました。",
+ "reconnectionPartial": "一部のストリームの再接続に失敗しました。",
+ "streamUnavailable": "ストリームプレビューは利用できません",
+ "reload": "再読み込み",
+ "connecting": "接続中…",
+ "streamTitle": "ストリーム {{number}}",
+ "valid": "有効",
+ "failed": "失敗",
+ "notTested": "未テスト",
+ "connectStream": "接続",
+ "connectingStream": "接続中",
+ "disconnectStream": "切断",
+ "estimatedBandwidth": "推定帯域幅",
+ "roles": "ロール",
+ "none": "なし",
+ "error": "エラー",
+ "streamValidated": "ストリーム {{number}} の検証に成功しました",
+ "streamValidationFailed": "ストリーム {{number}} の検証に失敗しました",
+ "saveError": "無効な構成です。設定を確認してください。",
+ "issues": {
+ "title": "ストリーム検証",
+ "videoCodecGood": "ビデオコーデックは {{codec}} です。",
+ "audioCodecGood": "オーディオコーデックは {{codec}} です。",
+ "noAudioWarning": "このストリームでは音声が検出されません。録画には音声が含まれません。",
+ "audioCodecRecordError": "録画に音声を含めるには AAC オーディオコーデックが必要です。",
+ "audioCodecRequired": "音声検出を有効にするには音声ストリームが必要です。",
+ "restreamingWarning": "録画ストリームでカメラへの接続数を減らすと、CPU 使用率がわずかに増加する場合があります。",
+ "hikvision": {
+ "substreamWarning": "サブストリーム1は低解像度に固定されています。多くの Hikvision 製カメラでは、追加のサブストリームが利用可能であり、カメラ本体の設定で有効化する必要があります。使用できる場合は、それらのストリームを確認して活用することを推奨します。"
+ },
+ "dahua": {
+ "substreamWarning": "サブストリーム1は低解像度に固定されています。多くの Dahua/Amcrest/EmpireTech 製カメラでは、追加のサブストリームが利用可能であり、カメラ本体の設定で有効化する必要があります。使用できる場合は、それらのストリームを確認して活用することを推奨します。"
+ }
+ },
+ "streamsTitle": "カメラ ストリーム",
+ "addStream": "ストリームを追加",
+ "addAnotherStream": "別のストリームを追加",
+ "streamUrl": "ストリーム URL",
+ "streamUrlPlaceholder": "rtsp://ユーザー名:パスワード@ホスト:ポート/パス",
+ "selectStream": "ストリームを選択",
+ "searchCandidates": "候補を検索…",
+ "noStreamFound": "ストリームが見つかりません",
+ "url": "URL",
+ "resolution": "解像度",
+ "selectResolution": "解像度を選択",
+ "quality": "品質",
+ "selectQuality": "品質を選択",
+ "roleLabels": {
+ "detect": "オブジェクト検出",
+ "record": "録画",
+ "audio": "音声"
+ },
+ "testStream": "接続をテスト",
+ "testSuccess": "ストリーム テスト成功!",
+ "testFailed": "ストリーム テスト失敗",
+ "testFailedTitle": "テスト失敗",
+ "connected": "接続済み",
+ "notConnected": "未接続",
+ "featuresTitle": "機能",
+ "go2rtc": "カメラへの接続数を削減",
+ "detectRoleWarning": "続行するには、少なくとも 1 つのストリームに「検出」ロールが必要です。",
+ "rolesPopover": {
+ "title": "ストリーム ロール",
+ "detect": "オブジェクト検出用のメイン フィードです。",
+ "record": "設定に基づいて映像フィードのセグメントを保存します。",
+ "audio": "音声ベース検出用のフィードです。"
+ },
+ "featuresPopover": {
+ "title": "ストリーム機能",
+ "description": "go2rtc の再配信を使用してカメラへの接続数を削減します。"
+ }
+ },
+ "title": "カメラを追加",
+ "description": "以下の手順に従って、Frigate に新しいカメラを追加します。",
+ "steps": {
+ "nameAndConnection": "名称と接続",
+ "streamConfiguration": "ストリーム設定",
+ "validationAndTesting": "検証とテスト",
+ "probeOrSnapshot": "プローブまたはスナップショット"
+ },
+ "save": {
+ "success": "新しいカメラ {{cameraName}} を保存しました。",
+ "failure": "保存エラー: {{cameraName}}。"
+ },
+ "testResultLabels": {
+ "resolution": "解像度",
+ "video": "ビデオ",
+ "audio": "オーディオ",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "有効なストリーム URL を入力してください",
+ "testFailed": "ストリームテストに失敗しました: {{error}}"
+ },
+ "step1": {
+ "description": "カメラの詳細を入力し、カメラを自動検出するか、メーカーを手動で選択してください。",
+ "cameraName": "カメラ名",
+ "cameraNamePlaceholder": "例: front_door または Back Yard Overview",
+ "host": "ホスト/IP アドレス",
+ "port": "ポート",
+ "username": "ユーザー名",
+ "usernamePlaceholder": "任意",
+ "password": "パスワード",
+ "passwordPlaceholder": "任意",
+ "selectTransport": "トランスポートプロトコルを選択",
+ "cameraBrand": "カメラブランド",
+ "selectBrand": "URL テンプレート用のカメラブランドを選択",
+ "customUrl": "カスタムストリーム URL",
+ "brandInformation": "ブランド情報",
+ "brandUrlFormat": "RTSP URL 形式が {{exampleUrl}} のカメラ向け",
+ "customUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "testConnection": "接続テスト",
+ "testSuccess": "接続テストに成功しました!",
+ "testFailed": "接続テストに失敗しました。入力内容を確認して再試行してください。",
+ "streamDetails": "ストリーム詳細",
+ "warnings": {
+ "noSnapshot": "設定されたストリームからスナップショットを取得できません。"
+ },
+ "errors": {
+ "brandOrCustomUrlRequired": "ホスト/IP とブランドを選択するか、「その他」を選んでカスタム URL を指定してください",
+ "nameRequired": "カメラ名は必須です",
+ "nameLength": "カメラ名は64文字以下である必要があります",
+ "invalidCharacters": "カメラ名に無効な文字が含まれています",
+ "nameExists": "このカメラ名は既に存在します",
+ "brands": {
+ "reolink-rtsp": "Reolink の RTSP は推奨されません。カメラ設定で http を有効にし、カメラウィザードを再起動することを推奨します。"
+ },
+ "customUrlRtspRequired": "カスタム URL は「rtsp://」で始まる必要があります。非 RTSP カメラ ストリームの場合は手動構成が必要です。"
+ },
+ "docs": {
+ "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras"
+ },
+ "connectionSettings": "接続設定",
+ "detectionMethod": "ストリーム検出方法",
+ "onvifPort": "ONVIF ポート",
+ "probeMode": "カメラをプローブ",
+ "manualMode": "手動選択",
+ "useDigestAuth": "ダイジェスト認証を使用",
+ "useDigestAuthDescription": "ONVIF に HTTP ダイジェスト認証を使用します。一部のカメラでは、通常の管理者ユーザーではなく専用の ONVIF ユーザー名/パスワードが必要な場合があります。",
+ "detectionMethodDescription": "(対応している場合)ONVIF を使用してカメラを自動設定し、カメラのストリーム URL を検出するか、カメラのブランドを手動で選択して事前定義された URL を使用します。カスタム RTSP URL を入力する場合は、手動設定を選択し、「その他」を選んでください。",
+ "onvifPortDescription": "ONVIF に対応しているカメラの場合、通常は 80 または 8080 です。"
+ },
+ "step2": {
+ "description": "選択した検出方法に応じて、カメラから利用可能なストリームを自動検出するか、手動で設定してください。",
+ "streamsTitle": "カメラストリーム",
+ "addStream": "ストリームを追加",
+ "addAnotherStream": "ストリームをさらに追加",
+ "streamTitle": "ストリーム {{number}}",
+ "streamUrl": "ストリーム URL",
+ "streamUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "url": "URL",
+ "resolution": "解像度",
+ "selectResolution": "解像度を選択",
+ "quality": "品質",
+ "selectQuality": "品質を選択",
+ "roles": "ロール",
+ "roleLabels": {
+ "detect": "物体検出",
+ "record": "録画",
+ "audio": "音声"
+ },
+ "testStream": "接続テスト",
+ "testSuccess": "接続テストに成功しました!",
+ "testFailed": "接続テストに失敗しました。入力を確認し、もう一度実行してください。",
+ "testFailedTitle": "テスト失敗",
+ "connected": "接続済み",
+ "notConnected": "未接続",
+ "featuresTitle": "機能",
+ "go2rtc": "カメラへの接続数を削減",
+ "detectRoleWarning": "\"detect\" ロールを持つストリームが少なくとも1つ必要です。",
+ "rolesPopover": {
+ "title": "ストリームロール",
+ "detect": "物体検出のメインフィード。",
+ "record": "設定に基づいて映像フィードのセグメントを保存します。",
+ "audio": "音声検出用のフィード。"
+ },
+ "featuresPopover": {
+ "title": "ストリーム機能",
+ "description": "go2rtc のリストリーミングを使用してカメラへの接続数を削減します。"
+ },
+ "streamDetails": "ストリームの詳細",
+ "probing": "カメラをプローブ中…",
+ "retry": "再試行",
+ "testing": {
+ "probingMetadata": "カメラのメタデータを取得中…",
+ "fetchingSnapshot": "カメラのスナップショットを取得中…"
+ },
+ "probeFailed": "カメラのプローブに失敗しました: {{error}}",
+ "probingDevice": "デバイスをプローブ中…",
+ "probeSuccessful": "プローブ成功",
+ "probeError": "プローブ エラー",
+ "probeNoSuccess": "プローブ失敗",
+ "deviceInfo": "デバイス情報",
+ "manufacturer": "メーカー",
+ "model": "モデル",
+ "firmware": "ファームウェア",
+ "profiles": "プロファイル",
+ "ptzSupport": "PTZ 対応",
+ "autotrackingSupport": "自動追跡対応",
+ "presets": "プリセット",
+ "rtspCandidates": "RTSP 候補",
+ "rtspCandidatesDescription": "カメラのプローブから以下の RTSP URL が見つかりました。接続をテストしてストリームのメタデータを確認してください。",
+ "candidateStreamTitle": "候補 {{number}}",
+ "useCandidate": "使用",
+ "uriCopy": "コピー",
+ "uriCopied": "URI をクリップボードにコピーしました",
+ "testConnection": "接続をテスト",
+ "toggleUriView": "クリックして URI の全表示を切り替え",
+ "errors": {
+ "hostRequired": "ホスト/IP アドレスは必須です"
+ },
+ "noRtspCandidates": "カメラから RTSP URL を取得できませんでした。認証情報が正しくないか、カメラが ONVIF に対応していない、または RTSP URL を取得する方法がサポートされていない可能性があります。RTSP URL を手動で入力してください。"
+ },
+ "step4": {
+ "description": "新しいカメラを保存する前の最終検証と分析です。保存前に各ストリームを接続してください。",
+ "validationTitle": "ストリーム検証",
+ "connectAllStreams": "すべてのストリームを接続",
+ "reconnectionSuccess": "再接続に成功しました。",
+ "reconnectionPartial": "一部のストリームで再接続に失敗しました。",
+ "streamUnavailable": "ストリームのプレビューを表示できません",
+ "reload": "再読み込み",
+ "connecting": "接続中…",
+ "streamTitle": "ストリーム {{number}}",
+ "valid": "有効",
+ "failed": "失敗",
+ "notTested": "未テスト",
+ "connectStream": "接続",
+ "connectingStream": "接続中",
+ "disconnectStream": "切断",
+ "estimatedBandwidth": "推定帯域幅",
+ "roles": "ロール",
+ "ffmpegModule": "ストリーム互換モードを使用",
+ "none": "なし",
+ "error": "エラー",
+ "streamValidated": "ストリーム {{number}} の検証に成功しました",
+ "streamValidationFailed": "ストリーム {{number}} の検証に失敗しました",
+ "saveAndApply": "新しいカメラを保存",
+ "saveError": "無効な設定です。設定を確認してください。",
+ "issues": {
+ "title": "ストリーム検証",
+ "videoCodecGood": "ビデオ コーデックは {{codec}} です。",
+ "audioCodecGood": "オーディオ コーデックは {{codec}} です。",
+ "resolutionHigh": "解像度 {{resolution}} はリソース使用量が増加する可能性があります。",
+ "resolutionLow": "解像度 {{resolution}} は小さなオブジェクトを確実に検出するには低すぎる可能性があります。",
+ "audioCodecRecordError": "録画で音声をサポートするには AAC オーディオ コーデックが必要です。",
+ "audioCodecRequired": "音声検出をサポートするには音声ストリームが必要です。",
+ "restreamingWarning": "録画用ストリームでカメラへの接続数を削減すると、CPU 使用率がわずかに増加する場合があります。",
+ "brands": {
+ "reolink-rtsp": "Reolink の RTSP は推奨されません。カメラのファームウェア設定で HTTP を有効にし、ウィザードを再起動してください。",
+ "reolink-http": "Reolink の HTTP ストリームは互換性向上のため FFmpeg を使用してください。このストリームで「ストリーム互換モードを使用」を有効にしてください。"
+ },
+ "dahua": {
+ "substreamWarning": "サブストリーム 1 は低解像度に固定されています。多くの Dahua / Amcrest / EmpireTech カメラは追加のサブストリームをサポートしており、カメラ設定で有効化する必要があります。利用可能であればそれらのストリームを使用することを推奨します。"
+ },
+ "hikvision": {
+ "substreamWarning": "サブストリーム 1 は低解像度に固定されています。多くの Hikvision カメラは追加のサブストリームをサポートしており、カメラ設定で有効化する必要があります。利用可能であればそれらのストリームを使用することを推奨します。"
+ },
+ "noAudioWarning": "このストリームでは音声が検出されていません。録画には音声が含まれません。"
+ },
+ "ffmpegModuleDescription": "何度か試してもストリームが読み込まれない場合は、このオプションを有効にしてください。有効にすると、Frigate は go2rtc と併用して ffmpeg モジュールを使用します。一部のカメラストリームでは、互換性が向上する場合があります。"
+ }
+ },
+ "cameraManagement": {
+ "title": "カメラ管理",
+ "addCamera": "新しいカメラを追加",
+ "editCamera": "カメラを編集:",
+ "selectCamera": "カメラを選択",
+ "backToSettings": "カメラ設定に戻る",
+ "streams": {
+ "title": "カメラの有効化/無効化",
+ "desc": "Frigate を再起動するまで一時的にカメラを無効化します。無効化すると、このカメラのストリーム処理は完全に停止し、検出・録画・デバッグは利用できません。ffprobe で取得しています。",
+ "fetching": "カメラデータを取得中",
+ "stream": "ストリーム {{idx}}",
+ "video": "動画:",
+ "codec": "コーデック:",
+ "resolution": "解像度:",
+ "fps": "FPS:",
+ "unknown": "不明",
+ "audio": "音声:",
+ "error": "エラー: {{error}}",
+ "tips": {
+ "title": "カメラプローブ情報"
+ }
+ },
+ "framesAndDetections": "フレーム / 検出",
+ "label": {
+ "camera": "カメラ",
+ "detect": "検出",
+ "skipped": "スキップ",
+ "ffmpeg": "FFmpeg",
+ "capture": "キャプチャ",
+ "overallFramesPerSecond": "全体フレーム/秒",
+ "overallDetectionsPerSecond": "全体検出/秒",
+ "overallSkippedDetectionsPerSecond": "全体スキップ検出/秒",
+ "cameraFfmpeg": "{{camName}} FFmpeg",
+ "cameraCapture": "{{camName}} キャプチャ",
+ "cameraDetect": "{{camName}} 検出",
+ "cameraFramesPerSecond": "{{camName}} フレーム/秒",
+ "cameraDetectionsPerSecond": "{{camName}} 検出/秒",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} スキップ検出/秒"
+ },
+ "toast": {
+ "success": {
+ "copyToClipboard": "プローブデータをクリップボードにコピーしました。"
+ },
+ "error": {
+ "unableToProbeCamera": "カメラをプローブできません: {{errorMessage}}"
+ }
+ }
+ },
+ "lastRefreshed": "最終更新: ",
+ "stats": {
+ "ffmpegHighCpuUsage": "{{camera}} の FFmpeg の CPU 使用率が高い({{ffmpegAvg}}%)",
+ "detectHighCpuUsage": "{{camera}} の検出の CPU 使用率が高い({{detectAvg}}%)",
+ "healthy": "システムは正常です",
+ "reindexingEmbeddings": "埋め込みを再インデックス中({{processed}}% 完了)",
+ "cameraIsOffline": "{{camera}} はオフラインです",
+ "detectIsSlow": "{{detect}} が遅い({{speed}} ms)",
+ "detectIsVerySlow": "{{detect}} が非常に遅い({{speed}} ms)",
+ "shmTooLow": "/dev/shm の割り当て({{total}} MB)は少なくとも {{min}} MB に増やす必要があります。"
+ },
+ "enrichments": {
+ "title": "高度解析",
+ "infPerSecond": "毎秒推論回数",
+ "embeddings": {
+ "image_embedding": "画像埋め込み",
+ "text_embedding": "テキスト埋め込み",
+ "face_recognition": "顔認識",
+ "plate_recognition": "ナンバープレート認識",
+ "image_embedding_speed": "画像埋め込み速度",
+ "face_embedding_speed": "顔埋め込み速度",
+ "face_recognition_speed": "顔認識速度",
+ "plate_recognition_speed": "ナンバープレート認識速度",
+ "text_embedding_speed": "テキスト埋め込み速度",
+ "yolov9_plate_detection_speed": "YOLOv9 ナンバープレート検出速度",
+ "yolov9_plate_detection": "YOLOv9 ナンバープレート検出",
+ "review_description": "レビュー説明",
+ "review_description_speed": "レビュー説明の処理速度",
+ "review_description_events_per_second": "レビュー説明",
+ "object_description": "オブジェクト説明",
+ "object_description_speed": "オブジェクト説明の処理速度",
+ "object_description_events_per_second": "オブジェクト説明",
+ "classification": "{{name}} の分類",
+ "classification_speed": "{{name}} 分類の処理速度",
+ "classification_events_per_second": "{{name}} 分類の毎秒イベント数"
+ },
+ "averageInf": "平均推論時間"
}
}
diff --git a/web/public/locales/ko/audio.json b/web/public/locales/ko/audio.json
index 0967ef424..d9db04e9f 100644
--- a/web/public/locales/ko/audio.json
+++ b/web/public/locales/ko/audio.json
@@ -1 +1,72 @@
-{}
+{
+ "crying": "울음",
+ "snoring": "코골이",
+ "singing": "노래",
+ "yell": "비명",
+ "speech": "말소리",
+ "babbling": "옹알이",
+ "bicycle": "자전거",
+ "a_capella": "아카펠라",
+ "accelerating": "가속",
+ "accordion": "아코디언",
+ "acoustic_guitar": "어쿠스틱 기타",
+ "car": "차량",
+ "motorcycle": "원동기",
+ "bus": "버스",
+ "train": "기차",
+ "boat": "보트",
+ "bird": "새",
+ "cat": "고양이",
+ "dog": "강아지",
+ "horse": "말",
+ "sheep": "양",
+ "skateboard": "스케이트보드",
+ "door": "문",
+ "mouse": "마우스",
+ "keyboard": "키보드",
+ "sink": "싱크대",
+ "blender": "블렌더",
+ "clock": "벽시계",
+ "scissors": "가위",
+ "hair_dryer": "헤어 드라이어",
+ "toothbrush": "칫솔",
+ "vehicle": "탈 것",
+ "animal": "동물",
+ "bark": "개",
+ "goat": "염소",
+ "bellow": "포효",
+ "whoop": "환성",
+ "whispering": "속삭임",
+ "laughter": "웃음",
+ "snicker": "낄낄 웃음",
+ "sigh": "한숨",
+ "choir": "합창",
+ "yodeling": "요들링",
+ "chant": "성가",
+ "mantra": "만트라",
+ "child_singing": "어린이 노래",
+ "synthetic_singing": "Synthetic Singing",
+ "rapping": "랩",
+ "humming": "허밍",
+ "groan": "신음",
+ "grunt": "으르렁",
+ "whistling": "휘파람",
+ "breathing": "숨쉬는 소리",
+ "wheeze": "헐떡임",
+ "gasp": "헐떡임",
+ "pant": "거친숨",
+ "snort": "코골이",
+ "cough": "기침",
+ "throat_clearing": "목 긁는 소리",
+ "sneeze": "재채기",
+ "sniff": "훌쩍",
+ "run": "달리기",
+ "shuffle": "Shuffle",
+ "footsteps": "발소리",
+ "chewing": "씹는 소리",
+ "biting": "치는 소리",
+ "gargling": "가글",
+ "stomach_rumble": "배 꼬르륵",
+ "burping": "트림",
+ "camera": "카메라"
+}
diff --git a/web/public/locales/ko/common.json b/web/public/locales/ko/common.json
index 0967ef424..e5c8ef9a9 100644
--- a/web/public/locales/ko/common.json
+++ b/web/public/locales/ko/common.json
@@ -1 +1,271 @@
-{}
+{
+ "readTheDocumentation": "문서 읽기",
+ "time": {
+ "untilForTime": "{{time}}까지",
+ "untilForRestart": "Frigate가 재시작될 때 까지.",
+ "10minutes": "10분",
+ "12hours": "12시간",
+ "1hour": "1시간",
+ "24hours": "24시간",
+ "30minutes": "30분",
+ "5minutes": "5분",
+ "untilRestart": "재시작 될 때까지",
+ "ago": "{{timeAgo}} 전",
+ "justNow": "지금 막",
+ "today": "오늘",
+ "yesterday": "어제",
+ "last7": "최근 7일",
+ "last14": "최근 14일",
+ "last30": "최근 30일",
+ "thisWeek": "이번 주",
+ "lastWeek": "저번 주",
+ "thisMonth": "이번 달",
+ "lastMonth": "저번 달",
+ "pm": "오후",
+ "am": "오전",
+ "yr": "{{time}}년",
+ "year_other": "{{time}} 년",
+ "mo": "{{time}}월",
+ "month_other": "{{time}} 월",
+ "d": "{{time}}일",
+ "day_other": "{{time}} 일",
+ "h": "{{time}}시",
+ "hour_other": "{{time}} 시",
+ "m": "{{time}}분",
+ "minute_other": "{{time}} 분",
+ "s": "{{time}}초",
+ "second_other": "{{time}} 초",
+ "formattedTimestamp": {
+ "12hour": "MMM d, h:mm:ss aaa",
+ "24hour": "MMM d, HH:mm:ss"
+ },
+ "formattedTimestamp2": {
+ "12hour": "MM/dd h:mm:ssa",
+ "24hour": "d MMM HH:mm:ss"
+ },
+ "formattedTimestampHourMinute": {
+ "12hour": "h:mm aaa",
+ "24hour": "HH:mm"
+ },
+ "formattedTimestampHourMinuteSecond": {
+ "12hour": "h:mm:ss aaa",
+ "24hour": "HH:mm:ss"
+ },
+ "formattedTimestampMonthDayHourMinute": {
+ "12hour": "MMM d, h:mm aaa",
+ "24hour": "MMM d, HH:mm"
+ },
+ "formattedTimestampMonthDayYear": {
+ "12hour": "MMM d, yyyy",
+ "24hour": "MMM d, yyyy"
+ },
+ "formattedTimestampMonthDayYearHourMinute": {
+ "12hour": "MMM d yyyy, h:mm aaa",
+ "24hour": "MMM d yyyy, HH:mm"
+ },
+ "formattedTimestampMonthDay": "MMM d",
+ "formattedTimestampFilename": {
+ "12hour": "MM-dd-yy-h-mm-ss-a",
+ "24hour": "MM-dd-yy-HH-mm-ss"
+ }
+ },
+ "notFound": {
+ "title": "404",
+ "documentTitle": "찾을 수 없음 - Frigate",
+ "desc": "페이지 찾을 수 없음"
+ },
+ "accessDenied": {
+ "title": "접근 거부",
+ "documentTitle": "접근 거부 - Frigate",
+ "desc": "이 페이지 접근 권한이 없습니다."
+ },
+ "menu": {
+ "user": {
+ "account": "계정",
+ "title": "사용자",
+ "current": "현재 사용자:{{user}}",
+ "anonymous": "익명",
+ "logout": "로그아웃",
+ "setPassword": "비밀번호 설정"
+ },
+ "system": "시스템",
+ "systemMetrics": "시스템 지표",
+ "configuration": "설정",
+ "systemLogs": "시스템 로그",
+ "settings": "설정",
+ "configurationEditor": "설정 편집기",
+ "languages": "언어",
+ "language": {
+ "en": "English (English)",
+ "es": "Español (Spanish)",
+ "zhCN": "简体中文 (Simplified Chinese)",
+ "hi": "हिन्दी (Hindi)",
+ "fr": "Français (French)",
+ "ar": "العربية (Arabic)",
+ "pt": "Português (Portuguese)",
+ "ptBR": "Português brasileiro (Brazilian Portuguese)",
+ "ru": "Русский (Russian)",
+ "de": "Deutsch (German)",
+ "ja": "日本語 (Japanese)",
+ "tr": "Türkçe (Turkish)",
+ "it": "Italiano (Italian)",
+ "nl": "Nederlands (Dutch)",
+ "sv": "Svenska (Swedish)",
+ "cs": "Čeština (Czech)",
+ "nb": "Norsk Bokmål (Norwegian Bokmål)",
+ "ko": "한국어 (Korean)",
+ "vi": "Tiếng Việt (Vietnamese)",
+ "fa": "فارسی (Persian)",
+ "pl": "Polski (Polish)",
+ "uk": "Українська (Ukrainian)",
+ "he": "עברית (Hebrew)",
+ "el": "Ελληνικά (Greek)",
+ "ro": "Română (Romanian)",
+ "hu": "Magyar (Hungarian)",
+ "fi": "Suomi (Finnish)",
+ "da": "Dansk (Danish)",
+ "sk": "Slovenčina (Slovak)",
+ "yue": "粵語 (Cantonese)",
+ "th": "ไทย (Thai)",
+ "ca": "Català (Catalan)",
+ "sr": "Српски (Serbian)",
+ "sl": "Slovenščina (Slovenian)",
+ "lt": "Lietuvių (Lithuanian)",
+ "bg": "Български (Bulgarian)",
+ "gl": "Galego (Galician)",
+ "id": "Bahasa Indonesia (Indonesian)",
+ "ur": "اردو (Urdu)",
+ "withSystem": {
+ "label": "시스템 설정 언어 사용"
+ }
+ },
+ "appearance": "화면 설정",
+ "darkMode": {
+ "label": "다크 모드",
+ "light": "라이트",
+ "dark": "다크",
+ "withSystem": {
+ "label": "시스템 설정에 따라 설정"
+ }
+ },
+ "withSystem": "시스템",
+ "theme": {
+ "label": "테마",
+ "blue": "파랑",
+ "green": "녹색",
+ "nord": "노드 (Nord)",
+ "red": "빨강",
+ "highcontrast": "고 대비",
+ "default": "기본값"
+ },
+ "help": "도움말",
+ "documentation": {
+ "title": "문서",
+ "label": "Frigate 문서"
+ },
+ "restart": "Frigate 재시작",
+ "live": {
+ "title": "실시간",
+ "allCameras": "모든 카메라",
+ "cameras": {
+ "title": "카메라",
+ "count_other": "{{count}} 카메라"
+ }
+ },
+ "review": "다시보기",
+ "explore": "탐색",
+ "export": "내보내기",
+ "uiPlayground": "UI 실험장",
+ "faceLibrary": "얼굴 라이브러리"
+ },
+ "unit": {
+ "speed": {
+ "mph": "mph",
+ "kph": "km/h"
+ },
+ "length": {
+ "feet": "피트",
+ "meters": "미터"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/hour",
+ "mbph": "MB/hour",
+ "gbph": "GB/hour"
+ }
+ },
+ "label": {
+ "back": "뒤로"
+ },
+ "button": {
+ "apply": "적용",
+ "reset": "리셋",
+ "done": "완료",
+ "enabled": "활성화됨",
+ "enable": "활성화",
+ "disabled": "비활성화됨",
+ "disable": "비활성화",
+ "save": "저장",
+ "saving": "저장 중…",
+ "cancel": "취소",
+ "close": "닫기",
+ "copy": "복사",
+ "back": "뒤로",
+ "history": "히스토리",
+ "fullscreen": "전체화면",
+ "exitFullscreen": "전체화면 나가기",
+ "pictureInPicture": "Picture in Picture",
+ "twoWayTalk": "양방향 말하기",
+ "cameraAudio": "카메라 오디오",
+ "on": "켜기",
+ "off": "끄기",
+ "edit": "편집",
+ "copyCoordinates": "코디네이트 복사",
+ "delete": "삭제",
+ "yes": "예",
+ "no": "아니오",
+ "download": "다운로드",
+ "info": "정보",
+ "suspended": "일시 정지됨",
+ "unsuspended": "재개",
+ "play": "재생",
+ "unselect": "선택 해제",
+ "export": "내보내기",
+ "deleteNow": "바로 삭제하기",
+ "next": "다음"
+ },
+ "toast": {
+ "copyUrlToClipboard": "클립보드에 URL이 복사되었습니다.",
+ "save": {
+ "title": "저장",
+ "error": {
+ "title": "설정 저장 실패: {{errorMessage}}",
+ "noMessage": "설정 저장이 실패했습니다"
+ }
+ }
+ },
+ "role": {
+ "title": "역할",
+ "admin": "관리자",
+ "viewer": "감시자",
+ "desc": "관리자는 Frigate UI에 모든 접근 권한이 있습니다. 감시자는 카메라 감시, 돌아보기, 과거 영상 조회만 가능합니다."
+ },
+ "pagination": {
+ "label": "나눠보기",
+ "previous": {
+ "title": "이전",
+ "label": "이전 페이지"
+ },
+ "next": {
+ "title": "다음",
+ "label": "다음 페이지"
+ },
+ "more": "더 많은 페이지"
+ },
+ "selectItem": "{{item}} 선택",
+ "information": {
+ "pixels": "{{area}}px"
+ }
+}
diff --git a/web/public/locales/ko/components/auth.json b/web/public/locales/ko/components/auth.json
index 0967ef424..65df51e36 100644
--- a/web/public/locales/ko/components/auth.json
+++ b/web/public/locales/ko/components/auth.json
@@ -1 +1,15 @@
-{}
+{
+ "form": {
+ "user": "사용자명",
+ "password": "비밀번호",
+ "login": "로그인",
+ "errors": {
+ "usernameRequired": "사용자명은 필수입니다",
+ "passwordRequired": "비밀번호는 필수입니다",
+ "rateLimit": "너무 많이 시도했습니다. 다음에 다시 시도하세요.",
+ "loginFailed": "로그인 실패",
+ "unknownError": "알려지지 않은 에러. 로그를 확인하세요.",
+ "webUnknownError": "알려지지 않은 에러. 콘솔 로그를 확인하세요."
+ }
+ }
+}
diff --git a/web/public/locales/ko/components/camera.json b/web/public/locales/ko/components/camera.json
index 0967ef424..67b1a2ee6 100644
--- a/web/public/locales/ko/components/camera.json
+++ b/web/public/locales/ko/components/camera.json
@@ -1 +1,86 @@
-{}
+{
+ "group": {
+ "label": "카메라 그룹",
+ "add": "카메라 그룹 추가",
+ "edit": "카메라 그룹 편집",
+ "delete": {
+ "label": "카메라 그룹 삭제",
+ "confirm": {
+ "title": "삭제 확인",
+ "desc": "정말로 카메라 그룹을 삭제하시겠습니까 {{name}}?"
+ }
+ },
+ "name": {
+ "label": "이름",
+ "placeholder": "이름을 입력하세요…",
+ "errorMessage": {
+ "mustLeastCharacters": "카메라 그룹 이름은 최소 2자 이상 써야합니다.",
+ "exists": "이미 존재하는 카메라 그룹 이름입니다.",
+ "nameMustNotPeriod": "카메라 그룹 이름에 마침표(.)를 넣을 수 없습니다.",
+ "invalid": "설정 불가능한 카메라 그룹 이름."
+ }
+ },
+ "cameras": {
+ "label": "카메라",
+ "desc": "이 그룹에 넣을 카메라 선택하기."
+ },
+ "icon": "아이콘",
+ "success": "카메라 그룹 {{name}} 저장되었습니다.",
+ "camera": {
+ "birdseye": "버드아이",
+ "setting": {
+ "label": "카메라 스트리밍 설정",
+ "title": "{{cameraName}} 스트리밍 설정",
+ "desc": "카메라 그룹 대시보드의 실시간 스트리밍 옵션을 변경하세요. 이 설정은 기기/브라우저에 따라 다릅니다.",
+ "audioIsAvailable": "이 카메라는 오디오 기능을 사용할 수 있습니다",
+ "audioIsUnavailable": "이 카메라는 오디오 기능을 사용할 수 없습니다",
+ "audio": {
+ "tips": {
+ "title": "오디오를 출력하려면 카메라가 지원하거나 go2rtc에서 설정해야합니다."
+ }
+ },
+ "stream": "스트림",
+ "placeholder": "스트림 선택",
+ "streamMethod": {
+ "label": "스트리밍 방식",
+ "placeholder": "스트리밍 방식 선택",
+ "method": {
+ "noStreaming": {
+ "label": "스트리밍 없음",
+ "desc": "카메라 이미지는 1분에 한 번만 보여지며 라이브 스트리밍은 되지 않습니다."
+ },
+ "smartStreaming": {
+ "label": "스마트 스트리밍 (추천함)",
+ "desc": "스마트 스트리밍은 감지되는 활동이 없을 때 대역폭과 자원을 절약하기 위해 1분마다 한 번 카메라 이미지를 업데이트합니다. 활동이 감지되면, 이미지는 자동으로 라이브 스트림으로 원활하게 전환됩니다."
+ },
+ "continuousStreaming": {
+ "label": "지속적인 스트리밍",
+ "desc": {
+ "title": "활동이 감지되지 않더라도 카메라 이미지가 대시보드에서 항상 실시간 스트림됩니다.",
+ "warning": "지속적인 스트리밍은 높은 대역폭 사용과 퍼포먼스 이슈를 발생할 수 있습니다. 사용에 주의해주세요."
+ }
+ }
+ }
+ },
+ "compatibilityMode": {
+ "label": "호환 모드",
+ "desc": "이 옵션은 카메라 라이브 스트림 화면의 색상이 왜곡 되었거나 이미지 오른쪽에 대각선이 나타날때만 사용하세요."
+ }
+ }
+ }
+ },
+ "debug": {
+ "options": {
+ "label": "설정",
+ "title": "옵션",
+ "showOptions": "옵션 보기",
+ "hideOptions": "옵션 숨기기"
+ },
+ "boundingBox": "감지 영역 상자",
+ "timestamp": "시간 기록",
+ "zones": "구역 (Zones)",
+ "mask": "마스크",
+ "motion": "움직임",
+ "regions": "영역 (Regions)"
+ }
+}
diff --git a/web/public/locales/ko/components/dialog.json b/web/public/locales/ko/components/dialog.json
index 0967ef424..f701526ef 100644
--- a/web/public/locales/ko/components/dialog.json
+++ b/web/public/locales/ko/components/dialog.json
@@ -1 +1,92 @@
-{}
+{
+ "restart": {
+ "title": "Frigate을 정말로 다시 시작할까요?",
+ "button": "재시작",
+ "restarting": {
+ "title": "Frigate이 재시작 중입니다",
+ "content": "이 페이지는 {{countdown}} 뒤에 새로 고침 됩니다.",
+ "button": "강제 재시작"
+ }
+ },
+ "explore": {
+ "plus": {
+ "submitToPlus": {
+ "label": "Frigate+에 등록하기"
+ },
+ "review": {
+ "question": {
+ "label": "Frigate +에 이 레이블 등록하기"
+ }
+ }
+ },
+ "video": {
+ "viewInHistory": "히스토리 보기"
+ }
+ },
+ "export": {
+ "time": {
+ "fromTimeline": "타임라인에서 선택하기",
+ "lastHour_other": "지난 시간",
+ "custom": "커스텀",
+ "start": {
+ "title": "시작 시간",
+ "label": "시작 시간 선택"
+ },
+ "end": {
+ "title": "종료 시간",
+ "label": "종료 시간 선택"
+ }
+ },
+ "name": {
+ "placeholder": "내보내기 이름"
+ },
+ "select": "선택",
+ "export": "내보내기",
+ "selectOrExport": "선택 또는 내보내기",
+ "toast": {
+ "success": "내보내기가 성공적으로 시작되었습니다. /exports 폴더에서 파일을 보실 수 있습니다.",
+ "error": {
+ "failed": "내보내기 시작 실패:{{error}}",
+ "endTimeMustAfterStartTime": "종료 시간은 시작 시간보다 뒤에 있어야합니다",
+ "noVaildTimeSelected": "유효한 시간 범위가 선택되지 않았습니다"
+ }
+ },
+ "fromTimeline": {
+ "saveExport": "내보내기 저장",
+ "previewExport": "내보내기 미리보기"
+ }
+ },
+ "streaming": {
+ "label": "스트림",
+ "restreaming": {
+ "disabled": "이 카메라는 재 스트리밍이 되지 않습니다.",
+ "desc": {
+ "title": "이 카메라를 위해 추가적인 라이브 뷰 옵션과 오디오를 go2rtc에서 설정하세요."
+ }
+ },
+ "showStats": {
+ "label": "스트림 통계 보기",
+ "desc": "이 옵션을 활성화하면 스트림 통계가 카메라 피드에 나타납니다."
+ },
+ "debugView": "디버그 뷰"
+ },
+ "search": {
+ "saveSearch": {
+ "label": "검색 저장",
+ "desc": "저장된 검색에 이름을 지정해주세요.",
+ "placeholder": "검색에 이름 입력하기",
+ "overwrite": "{{searchName}} (이/가) 이미 존재합니다. 값을 덮어 씌웁니다.",
+ "success": "{{searchName}} 검색이 저장되었습니다.",
+ "button": {
+ "save": {
+ "label": "이 검색 저장하기"
+ }
+ }
+ }
+ },
+ "recording": {
+ "confirmDelete": {
+ "title": "삭제 확인"
+ }
+ }
+}
diff --git a/web/public/locales/ko/components/filter.json b/web/public/locales/ko/components/filter.json
index 0967ef424..942b97c7d 100644
--- a/web/public/locales/ko/components/filter.json
+++ b/web/public/locales/ko/components/filter.json
@@ -1 +1,39 @@
-{}
+{
+ "filter": "필터",
+ "labels": {
+ "label": "레이블",
+ "all": {
+ "title": "모든 레이블",
+ "short": "레이블"
+ }
+ },
+ "zones": {
+ "label": "구역",
+ "all": {
+ "title": "모든 구역",
+ "short": "구역"
+ }
+ },
+ "dates": {
+ "selectPreset": "프리셋 선택",
+ "all": {
+ "title": "모든 날짜",
+ "short": "날짜"
+ }
+ },
+ "timeRange": "시간 구역",
+ "subLabels": {
+ "label": "서브 레이블",
+ "all": "모든 서브 레이블"
+ },
+ "more": "더 많은 필터",
+ "classes": {
+ "label": "분류",
+ "all": {
+ "title": "모든 분류"
+ }
+ },
+ "reset": {
+ "label": "기본값으로 필터 초기화"
+ }
+}
diff --git a/web/public/locales/ko/components/icons.json b/web/public/locales/ko/components/icons.json
index 0967ef424..fb1b47c03 100644
--- a/web/public/locales/ko/components/icons.json
+++ b/web/public/locales/ko/components/icons.json
@@ -1 +1,8 @@
-{}
+{
+ "iconPicker": {
+ "selectIcon": "아이콘을 선택해주세요",
+ "search": {
+ "placeholder": "아이콘 검색 중…"
+ }
+ }
+}
diff --git a/web/public/locales/ko/components/input.json b/web/public/locales/ko/components/input.json
index 0967ef424..00a19b702 100644
--- a/web/public/locales/ko/components/input.json
+++ b/web/public/locales/ko/components/input.json
@@ -1 +1,10 @@
-{}
+{
+ "button": {
+ "downloadVideo": {
+ "label": "비디오 다운로드",
+ "toast": {
+ "success": "다시보기 항목 다운로드가 시작되었습니다."
+ }
+ }
+ }
+}
diff --git a/web/public/locales/ko/components/player.json b/web/public/locales/ko/components/player.json
index 0967ef424..38ef7daac 100644
--- a/web/public/locales/ko/components/player.json
+++ b/web/public/locales/ko/components/player.json
@@ -1 +1,51 @@
-{}
+{
+ "submitFrigatePlus": {
+ "submit": "제출",
+ "title": "이 프레임을 Frigate+에 제출하시겠습니까?"
+ },
+ "stats": {
+ "bandwidth": {
+ "short": "대역폭",
+ "title": "대역폭:"
+ },
+ "latency": {
+ "short": {
+ "title": "지연",
+ "value": "{{seconds}} 초"
+ },
+ "title": "지연:",
+ "value": "{{seconds}} 초"
+ },
+ "streamType": {
+ "short": "종류",
+ "title": "스트림 종류:"
+ },
+ "totalFrames": "총 프레임:",
+ "droppedFrames": {
+ "title": "손실 프레임:",
+ "short": {
+ "title": "손실됨",
+ "value": "{{droppedFrames}} 프레임"
+ }
+ },
+ "decodedFrames": "복원된 프레임:",
+ "droppedFrameRate": "프레임 손실률:"
+ },
+ "noRecordingsFoundForThisTime": "이 시간대에는 녹화본이 없습니다",
+ "noPreviewFound": "미리 보기를 찾을 수 없습니다",
+ "noPreviewFoundFor": "{{cameraName}}에 미리보기를 찾을 수 없습니다",
+ "livePlayerRequiredIOSVersion": "이 라이브 스트림 방식은 iOS 17.1 이거나 높은 버전이 필요합니다.",
+ "streamOffline": {
+ "title": "스트림 오프라인",
+ "desc": "{{cameraName}} 카메라에 감지(detect) 스트림의 프레임을 얻지 못했습니다. 에러 로그를 확인하세요"
+ },
+ "cameraDisabled": "카메라를 이용할 수 없습니다",
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "Frigate+에 프레임이 성공적으로 제출됐습니다"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "Frigate+에 프레임을 보내지 못했습니다"
+ }
+ }
+}
diff --git a/web/public/locales/ko/objects.json b/web/public/locales/ko/objects.json
index 0967ef424..e3506b15d 100644
--- a/web/public/locales/ko/objects.json
+++ b/web/public/locales/ko/objects.json
@@ -1 +1,120 @@
-{}
+{
+ "person": "사람",
+ "bicycle": "자전거",
+ "car": "차량",
+ "motorcycle": "원동기",
+ "airplane": "비행기",
+ "bus": "버스",
+ "train": "기차",
+ "boat": "보트",
+ "traffic_light": "신호등",
+ "fire_hydrant": "소화전",
+ "street_sign": "도로 표지판",
+ "stop_sign": "정지 표지판",
+ "parking_meter": "주차 요금 정산기",
+ "bench": "벤치",
+ "bird": "새",
+ "cat": "고양이",
+ "dog": "강아지",
+ "horse": "말",
+ "sheep": "양",
+ "cow": "소",
+ "elephant": "코끼리",
+ "bear": "곰",
+ "zebra": "얼룩말",
+ "giraffe": "기린",
+ "hat": "모자",
+ "backpack": "백팩",
+ "umbrella": "우산",
+ "shoe": "신발",
+ "eye_glasses": "안경",
+ "handbag": "핸드백",
+ "tie": "타이",
+ "suitcase": "슈트케이스",
+ "frisbee": "프리스비",
+ "skis": "스키",
+ "snowboard": "스노우보드",
+ "sports_ball": "스포츠 볼",
+ "kite": "연",
+ "baseball_bat": "야구 방망이",
+ "baseball_glove": "야구 글로브",
+ "skateboard": "스케이트보드",
+ "surfboard": "서핑보드",
+ "tennis_racket": "테니스 라켓",
+ "bottle": "병",
+ "plate": "번호판",
+ "wine_glass": "와인잔",
+ "cup": "컵",
+ "fork": "포크",
+ "knife": "칼",
+ "spoon": "숟가락",
+ "bowl": "보울",
+ "banana": "바나나",
+ "apple": "사과",
+ "sandwich": "샌드위치",
+ "orange": "오렌지",
+ "broccoli": "브로콜리",
+ "carrot": "당근",
+ "hot_dog": "핫도그",
+ "pizza": "피자",
+ "donut": "도넛",
+ "cake": "케이크",
+ "chair": "의자",
+ "couch": "소파",
+ "potted_plant": "화분",
+ "bed": "침대",
+ "mirror": "거울",
+ "dining_table": "식탁",
+ "window": "창문",
+ "desk": "책상",
+ "toilet": "화장실",
+ "door": "문",
+ "tv": "TV",
+ "laptop": "랩탑",
+ "mouse": "마우스",
+ "remote": "리모콘",
+ "keyboard": "키보드",
+ "cell_phone": "휴대폰",
+ "microwave": "전자레인지",
+ "oven": "오븐",
+ "toaster": "토스터기",
+ "sink": "싱크대",
+ "refrigerator": "냉장고",
+ "blender": "블렌더",
+ "book": "책",
+ "clock": "벽시계",
+ "vase": "꽃병",
+ "scissors": "가위",
+ "teddy_bear": "테디베어",
+ "hair_dryer": "헤어 드라이어",
+ "toothbrush": "칫솔",
+ "hair_brush": "빗",
+ "vehicle": "탈 것",
+ "squirrel": "다람쥐",
+ "deer": "사슴",
+ "animal": "동물",
+ "bark": "개",
+ "fox": "여우",
+ "goat": "염소",
+ "rabbit": "토끼",
+ "raccoon": "라쿤",
+ "robot_lawnmower": "로봇 잔디깎기",
+ "waste_bin": "쓰레기통",
+ "on_demand": "수동",
+ "face": "얼굴",
+ "license_plate": "차량 번호판",
+ "package": "패키지",
+ "bbq_grill": "바베큐 그릴",
+ "amazon": "Amazon",
+ "usps": "USPS",
+ "ups": "UPS",
+ "fedex": "FedEx",
+ "dhl": "DHL",
+ "an_post": "An Post",
+ "purolator": "Purolator",
+ "postnl": "PostNL",
+ "nzpost": "NZPost",
+ "postnord": "PostNord",
+ "gls": "GLS",
+ "dpd": "DPD"
+}
diff --git a/web/public/locales/ko/views/classificationModel.json b/web/public/locales/ko/views/classificationModel.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ko/views/classificationModel.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ko/views/configEditor.json b/web/public/locales/ko/views/configEditor.json
index 0967ef424..bb8a84c2a 100644
--- a/web/public/locales/ko/views/configEditor.json
+++ b/web/public/locales/ko/views/configEditor.json
@@ -1 +1,18 @@
-{}
+{
+ "documentTitle": "설정 편집기 - Frigate",
+ "configEditor": "설정 편집기",
+ "safeConfigEditor": "설정 편집기 (안전 모드)",
+ "safeModeDescription": "설정 오류로 인해 Frigate가 안전 모드로 전환되었습니다.",
+ "copyConfig": "설정 복사",
+ "saveAndRestart": "저장 & 재시작",
+ "saveOnly": "저장만 하기",
+ "confirm": "저장 없이 나갈까요?",
+ "toast": {
+ "success": {
+ "copyToClipboard": "설정이 클립보드에 저장되었습니다."
+ },
+ "error": {
+ "savingError": "설정 저장 오류"
+ }
+ }
+}
diff --git a/web/public/locales/ko/views/events.json b/web/public/locales/ko/views/events.json
index 0967ef424..971494a81 100644
--- a/web/public/locales/ko/views/events.json
+++ b/web/public/locales/ko/views/events.json
@@ -1 +1,51 @@
-{}
+{
+ "alerts": "경보",
+ "detections": "대상 감지",
+ "motion": {
+ "label": "움직임 감지",
+ "only": "움직임 감지만"
+ },
+ "allCameras": "모든 카메라",
+ "empty": {
+ "alert": "다시 볼 '경보' 영상이 없습니다",
+ "detection": "다시 볼 '대상 감지' 영상이 없습니다",
+ "motion": "움직임 감지 데이터가 없습니다"
+ },
+ "timeline": "타임라인",
+ "timeline.aria": "타임라인 선택",
+ "events": {
+ "label": "이벤트",
+ "aria": "이벤트 선택",
+ "noFoundForTimePeriod": "이 시간대에 이벤트가 없습니다."
+ },
+ "detail": {
+ "noDataFound": "다시 볼 상세 데이터가 없습니다",
+ "aria": "상세 보기",
+ "trackedObject_one": "추적 대상",
+ "trackedObject_other": "추적 대상",
+ "noObjectDetailData": "상세 보기 데이터가 없습니다."
+ },
+ "objectTrack": {
+ "trackedPoint": "추적 포인트",
+ "clickToSeek": "이 시점으로 이동"
+ },
+ "documentTitle": "다시 보기 - Frigate",
+ "recordings": {
+ "documentTitle": "녹화 - Frigate"
+ },
+ "calendarFilter": {
+ "last24Hours": "최근 24시간"
+ },
+ "markAsReviewed": "'다시 봤음'으로 표시",
+ "markTheseItemsAsReviewed": "이 영상들을 '다시 봤음'으로 표시",
+ "newReviewItems": {
+ "label": "새로운 '다시 보기' 영상 보기",
+ "button": "새로운 '다시 보기' 영상"
+ },
+ "selected_one": "{{count}} 선택됨",
+ "selected_other": "{{count}} 선택됨",
+ "camera": "카메라",
+ "detected": "감지됨",
+ "suspiciousActivity": "수상한 행동",
+ "threateningActivity": "위협적인 행동"
+}
diff --git a/web/public/locales/ko/views/explore.json b/web/public/locales/ko/views/explore.json
index 0967ef424..231eade30 100644
--- a/web/public/locales/ko/views/explore.json
+++ b/web/public/locales/ko/views/explore.json
@@ -1 +1,31 @@
-{}
+{
+ "documentTitle": "탐색 - Frigate",
+ "generativeAI": "생성형 AI",
+ "exploreMore": "{{label}} 더 많은 감지 대상 탐색하기",
+ "exploreIsUnavailable": {
+ "title": "탐색을 사용할 수 없습니다",
+ "embeddingsReindexing": {
+ "context": "감지 정보 재처리가 완료되면 탐색할 수 있습니다.",
+ "startingUp": "시작 중…",
+ "estimatedTime": "예상 남은시간:",
+ "finishingShortly": "곧 완료됩니다",
+ "step": {
+ "thumbnailsEmbedded": "처리된 썸네일: ",
+ "descriptionsEmbedded": "처리된 설명: ",
+ "trackedObjectsProcessed": "처리된 추적 감지: "
+ }
+ },
+ "downloadingModels": {
+ "context": "Frigate가 시맨틱 검색 기능을 지원하기 위해 필요한 임베딩 모델을 다운로드하고 있습니다. 네트워크 연결 속도에 따라 몇 분 정도 소요될 수 있습니다.",
+ "setup": {
+ "visionModel": "Vision model",
+ "visionModelFeatureExtractor": "Vision model feature extractor",
+ "textModel": "Text model",
+ "textTokenizer": "Text tokenizer"
+ }
+ }
+ },
+ "details": {
+ "timestamp": "시간 기록"
+ }
+}
diff --git a/web/public/locales/ko/views/exports.json b/web/public/locales/ko/views/exports.json
index 0967ef424..f4c902602 100644
--- a/web/public/locales/ko/views/exports.json
+++ b/web/public/locales/ko/views/exports.json
@@ -1 +1,17 @@
-{}
+{
+ "documentTitle": "내보내기 - Frigate",
+ "search": "검색",
+ "noExports": "내보내기가 없습니다",
+ "deleteExport": "내보내기 삭제",
+ "deleteExport.desc": "{{exportName}}을 지우시겠습니까?",
+ "editExport": {
+ "title": "내보내기 이름 변경",
+ "desc": "이 내보내기의 새 이름을 입력하세요.",
+ "saveExport": "내보내기 저장"
+ },
+ "toast": {
+ "error": {
+ "renameExportFailed": "내보내기 이름 변경에 실패했습니다: {{errorMessage}}"
+ }
+ }
+}
diff --git a/web/public/locales/ko/views/faceLibrary.json b/web/public/locales/ko/views/faceLibrary.json
index 0967ef424..9f001d24d 100644
--- a/web/public/locales/ko/views/faceLibrary.json
+++ b/web/public/locales/ko/views/faceLibrary.json
@@ -1 +1,84 @@
-{}
+{
+ "description": {
+ "placeholder": "이 모음집의 이름을 입력해주세요",
+ "addFace": "안면인식 라이브러리에서 첫 사진을 업로드해 새로운 컬렉션을 만들어보세요.",
+ "invalidName": "잘못된 이름입니다. 이름은 문자, 숫자, 공백, 따옴표 ('), 밑줄 (_), 그리고 붙임표 (-)만 포함이 가능합니다."
+ },
+ "details": {
+ "person": "사람",
+ "subLabelScore": "보조 레이블 신뢰도",
+ "face": "얼굴 상세정보",
+ "timestamp": "시간 기록",
+ "unknown": "알 수 없음"
+ },
+ "selectItem": "{{item}} 선택",
+ "documentTitle": "얼굴 라이브러리 - Frigate",
+ "uploadFaceImage": {
+ "title": "얼굴 사진 올리기"
+ },
+ "collections": "모음집",
+ "createFaceLibrary": {
+ "title": "모음집 만들기",
+ "desc": "새로운 모음집 만들기",
+ "new": "새 얼굴 만들기"
+ },
+ "steps": {
+ "faceName": "얼굴 이름 입력",
+ "uploadFace": "얼굴 사진 올리기",
+ "nextSteps": "다음 단계"
+ },
+ "train": {
+ "title": "학습",
+ "aria": "학습 선택"
+ },
+ "selectFace": "얼굴 선택",
+ "deleteFaceLibrary": {
+ "title": "이름 삭제"
+ },
+ "deleteFaceAttempts": {
+ "title": "얼굴 삭제"
+ },
+ "renameFace": {
+ "title": "얼굴 이름 바꾸기",
+ "desc": "{{name}}의 새 이름을 입력하세요"
+ },
+ "button": {
+ "deleteFaceAttempts": "얼굴 삭제",
+ "addFace": "얼굴 추가",
+ "renameFace": "얼굴 이름 바꾸기",
+ "deleteFace": "얼굴 삭제",
+ "uploadImage": "이미지 올리기",
+ "reprocessFace": "얼굴 재조정"
+ },
+ "imageEntry": {
+ "validation": {
+ "selectImage": "이미지 파일을 선택해주세요."
+ },
+ "dropActive": "여기에 이미지 놓기…",
+ "dropInstructions": "이미지를 끌어다 놓거나 여기에 붙여넣으세요. 선택할 수도 있습니다.",
+ "maxSize": "최대 용량: {{size}}MB"
+ },
+ "nofaces": "얼굴을 찾을 수 없습니다",
+ "pixels": "{{area}}px",
+ "trainFaceAs": "얼굴을 다음과 같이 훈련하기:",
+ "trainFace": "얼굴 훈련하기",
+ "toast": {
+ "success": {
+ "uploadedImage": "이미지 업로드에 성공했습니다.",
+ "addFaceLibrary": "{{name}} 을 성공적으로 얼굴 라이브러리에 추가했습니다!",
+ "deletedFace_other": "{{count}} 얼굴을 성공적으로 삭제했습니다.",
+ "renamedFace": "얼굴 이름을 {{name}} 으로 성공적으로 바꿨습니다",
+ "trainedFace": "얼굴 훈련을 성공적으로 마쳤습니다.",
+ "updatedFaceScore": "얼굴 신뢰도를 성공적으로 업데이트 했습니다."
+ },
+ "error": {
+ "uploadingImageFailed": "이미지 업로드 실패:{{errorMessage}}",
+ "addFaceLibraryFailed": "얼굴 이름 설정 실패:{{errorMessage}}",
+ "deleteFaceFailed": "삭제 실패:{{errorMessage}}",
+ "deleteNameFailed": "이름 삭제 실패:{{errorMessage}}",
+ "renameFaceFailed": "이름 바꾸기 실패:{{errorMessage}}",
+ "trainFailed": "훈련 실패:{{errorMessage}}",
+ "updateFaceScoreFailed": "얼굴 신뢰도 업데이트 실패:{{errorMessage}}"
+ }
+ }
+}
diff --git a/web/public/locales/ko/views/live.json b/web/public/locales/ko/views/live.json
index 0967ef424..bfc44d18f 100644
--- a/web/public/locales/ko/views/live.json
+++ b/web/public/locales/ko/views/live.json
@@ -1 +1,183 @@
-{}
+{
+ "documentTitle": "실시간 보기 - Frigate",
+ "documentTitle.withCamera": "{{camera}} - 실시간 보기 - Frigate",
+ "lowBandwidthMode": "저대역폭 모드",
+ "twoWayTalk": {
+ "enable": "양방향 말하기 활성화",
+ "disable": "양방향 말하기 비활성화"
+ },
+ "cameraAudio": {
+ "enable": "카메라 오디오 활성화",
+ "disable": "카메라 오디오 비활성화"
+ },
+ "ptz": {
+ "move": {
+ "clickMove": {
+ "label": "클릭해서 카메라 중앙 배치",
+ "enable": "클릭해서 움직이기 기능 활성화",
+ "disable": "클릭해서 움직이기 기능 비활성화"
+ },
+ "left": {
+ "label": "PTZ 카메라 왼쪽으로 이동"
+ },
+ "up": {
+ "label": "PTZ 카메라 위로 이동"
+ },
+ "down": {
+ "label": "PTZ 카메라 아래로 이동"
+ },
+ "right": {
+ "label": "PTZ 카메라 오른쪽으로 이동"
+ }
+ },
+ "zoom": {
+ "in": {
+ "label": "PTZ 카메라 확대"
+ },
+ "out": {
+ "label": "PTZ 카메라 축소"
+ }
+ },
+ "focus": {
+ "in": {
+ "label": "PTZ 카메라 포커스 인"
+ },
+ "out": {
+ "label": "PTZ 카메라 포커스 아웃"
+ }
+ },
+ "frame": {
+ "center": {
+ "label": "클릭해서 PTZ 카메라 중앙 배치"
+ }
+ },
+ "presets": "PTZ 카메라 프리셋"
+ },
+ "camera": {
+ "enable": "카메라 활성화",
+ "disable": "카메라 비활성화"
+ },
+ "muteCameras": {
+ "enable": "모든 카메라 음소거",
+ "disable": "모든 카메라 음소거 해제"
+ },
+ "detect": {
+ "enable": "감지 활성화",
+ "disable": "감지 비활성화"
+ },
+ "recording": {
+ "enable": "녹화 활성화",
+ "disable": "녹화 비활성화"
+ },
+ "snapshots": {
+ "enable": "스냅샷 활성화",
+ "disable": "스냅샷 비활성화"
+ },
+ "audioDetect": {
+ "enable": "오디오 감지 활성화",
+ "disable": "오디오 감지 비활성화"
+ },
+ "transcription": {
+ "enable": "실시간 오디오 자막 활성화",
+ "disable": "실시간 오디오 자막 비활성화"
+ },
+ "autotracking": {
+ "enable": "자동 추적 활성화",
+ "disable": "자동 추적 비활성화"
+ },
+ "streamStats": {
+ "enable": "스트림 통계 보기",
+ "disable": "스트림 통계 숨기기"
+ },
+ "manualRecording": {
+ "title": "수동 녹화",
+ "tips": "이 카메라의 녹화 보관 설정에 따라 인스턴트 스냅샷을 다운로드하거나 수동 녹화를 시작할 수 있습니다.",
+ "playInBackground": {
+ "label": "백그라운드에서 재생",
+ "desc": "이 옵션을 활성화하면 플레이어가 숨겨져도 계속 스트리밍됩니다."
+ },
+ "showStats": {
+ "label": "통계 보기",
+ "desc": "이 옵션을 활성화하면 카메라 피드에 스트림 통계가 나타납니다."
+ },
+ "debugView": "디버그 보기",
+ "start": "수동 녹화 시작",
+ "started": "수동 녹화 시작되었습니다.",
+ "failedToStart": "수동 녹화 시작이 실패했습니다.",
+ "recordDisabledTips": "이 카메라 설정에서 녹화가 비활성화 되었거나 제한되어 있어 스냅샷만 저장됩니다.",
+ "end": "수동 녹화 종료",
+ "ended": "수동 녹화가 종료되었습니다.",
+ "failedToEnd": "수동 녹화 종료가 실패했습니다."
+ },
+ "streamingSettings": "스트리밍 설정",
+ "notifications": "알림",
+ "audio": "오디오",
+ "suspend": {
+ "forTime": "일시정지 시간: "
+ },
+ "stream": {
+ "title": "스트림",
+ "audio": {
+ "available": "이 스트림에서 오디오를 사용할 수 있습니다",
+ "unavailable": "이 스트림에서 오디오를 사용할 수 없습니다",
+ "tips": {
+ "title": "이 스트림에서 오디오를 사용하려면 카메라에서 오디오를 출력하고 go2rtc에서 설정해야 합니다."
+ }
+ },
+ "debug": {
+ "picker": "디버그 모드에선 스트림 모드를 선택할 수 없습니다. 디버그 뷰에서는 항상 감지(Detect) 역할로 설정한 스트림을 사용합니다."
+ },
+ "twoWayTalk": {
+ "tips": "양방향 말하기 기능을 사용하려면 기기에서 기능을 지원해야하며 WebRTC를 설정해야합니다.",
+ "available": "이 기기는 양방향 말하기 기능을 사용할 수 있습니다",
+ "unavailable": "이 기기는 양방향 말하기 기능을 사용할 수 없습니다"
+ },
+ "lowBandwidth": {
+ "tips": "버퍼링 또는 스트림 오류로 실시간 화면을 저대역폭 모드로 변경되었습니다.",
+ "resetStream": "스트림 리셋"
+ },
+ "playInBackground": {
+ "label": "백그라운드에서 재생",
+ "tips": "이 옵션을 활성화하면 플레이어가 숨겨져도 스트리밍이 지속됩니다."
+ }
+ },
+ "cameraSettings": {
+ "title": "{{camera}} 설정",
+ "cameraEnabled": "카메라 활성화",
+ "objectDetection": "대상 감지",
+ "recording": "녹화",
+ "snapshots": "스냅샷",
+ "audioDetection": "오디오 감지",
+ "transcription": "오디오 자막",
+ "autotracking": "자동 추적"
+ },
+ "history": {
+ "label": "이전 영상 보기"
+ },
+ "effectiveRetainMode": {
+ "modes": {
+ "all": "전체",
+ "motion": "움직임 감지",
+ "active_objects": "활성 대상"
+ },
+ "notAllTips": "{{source}} 녹화 보관 설정이 mode: {{effectiveRetainMode}}로 되어 있어, 이 수동 녹화는 {{effectiveRetainModeName}}이(가) 있는 구간만 저장됩니다."
+ },
+ "editLayout": {
+ "label": "레이아웃 편집",
+ "group": {
+ "label": "카메라 그룹 편집"
+ },
+ "exitEdit": "편집 종료"
+ },
+ "noCameras": {
+ "title": "설정된 카메라 없음",
+ "description": "카메라를 연결해 시작하세요.",
+ "buttonText": "카메라 추가"
+ },
+ "snapshot": {
+ "takeSnapshot": "인스턴트 스냅샷 다운로드",
+ "noVideoSource": "스냅샷 찍을 비디오 소스가 없습니다.",
+ "captureFailed": "스냅샷 캡쳐를 하지 못했습니다.",
+ "downloadStarted": "스냅샷 다운로드가 시작됐습니다."
+ }
+}
diff --git a/web/public/locales/ko/views/recording.json b/web/public/locales/ko/views/recording.json
index 0967ef424..2aa9934de 100644
--- a/web/public/locales/ko/views/recording.json
+++ b/web/public/locales/ko/views/recording.json
@@ -1 +1,12 @@
-{}
+{
+ "filter": "필터",
+ "export": "내보내기",
+ "calendar": "날짜",
+ "filters": "필터",
+ "toast": {
+ "error": {
+ "noValidTimeSelected": "올바른 시간 범위를 선택하세요",
+ "endTimeMustAfterStartTime": "종료 시간은 시작 시간보다 뒤에 있어야합니다"
+ }
+ }
+}
diff --git a/web/public/locales/ko/views/search.json b/web/public/locales/ko/views/search.json
index 0967ef424..f7a6cfd83 100644
--- a/web/public/locales/ko/views/search.json
+++ b/web/public/locales/ko/views/search.json
@@ -1 +1,7 @@
-{}
+{
+ "search": "검색",
+ "savedSearches": "저장된 검색들",
+ "button": {
+ "clear": "검색 초기화"
+ }
+}
diff --git a/web/public/locales/ko/views/settings.json b/web/public/locales/ko/views/settings.json
index 0967ef424..a5b1d5580 100644
--- a/web/public/locales/ko/views/settings.json
+++ b/web/public/locales/ko/views/settings.json
@@ -1 +1,122 @@
-{}
+{
+ "triggers": {
+ "dialog": {
+ "form": {
+ "threshold": {
+ "title": "임계치"
+ },
+ "name": {
+ "title": "이름"
+ },
+ "type": {
+ "title": "종류",
+ "placeholder": "트리거 종류 선택"
+ }
+ },
+ "createTrigger": {
+ "title": "트리거 생성"
+ }
+ },
+ "actions": {
+ "notification": "알림 전송"
+ }
+ },
+ "documentTitle": {
+ "default": "설정 - Frigate",
+ "authentication": "인증 설정 - Frigate",
+ "camera": "카메라 설정 - Frigate",
+ "enrichments": "고급 설정 - Frigate",
+ "masksAndZones": "마스크와 구역 편집기 - Frigate",
+ "motionTuner": "움직임 감지 조정 - Frigate",
+ "object": "디버그 - Frigate",
+ "general": "일반 설정 - Frigate",
+ "frigatePlus": "Frigate+ 설정 - Frigate",
+ "notifications": "알림 설정 - Frigate",
+ "cameraManagement": "카메라 관리 - Frigate",
+ "cameraReview": "카메라 다시보기 설정 - Frigate"
+ },
+ "users": {
+ "table": {
+ "actions": "액션"
+ }
+ },
+ "menu": {
+ "ui": "UI",
+ "enrichments": "고급",
+ "cameras": "카메라 설정",
+ "masksAndZones": "마스크 / 구역",
+ "motionTuner": "움직임 감지 조정",
+ "triggers": "트리거",
+ "debug": "디버그",
+ "users": "사용자",
+ "roles": "역할",
+ "notifications": "알림",
+ "frigateplus": "Frigate+",
+ "cameraManagement": "관리",
+ "cameraReview": "다시보기"
+ },
+ "dialog": {
+ "unsavedChanges": {
+ "title": "저장되지 않은 변경 사항이 있습니다.",
+ "desc": "계속하기 전에 변경 사항을 저장하시겠습니까?"
+ }
+ },
+ "cameraSetting": {
+ "camera": "카메라",
+ "noCamera": "카메라 없음"
+ },
+ "general": {
+ "title": "일반 세팅",
+ "liveDashboard": {
+ "title": "실시간 보기 대시보드",
+ "automaticLiveView": {
+ "label": "자동으로 실시간 보기 전환",
+ "desc": "활동이 감지되면 자동으로 실시간 보기로 전환합니다. 이 옵션을 끄면 대시보드의 카메라 화면은 1분마다 한 번만 갱신됩니다."
+ },
+ "playAlertVideos": {
+ "label": "경보 영상 보기",
+ "desc": "기본적으로 실시간 보기 대시보드의 최근 경보 영상을 작은 반복 영상으로 재생됩니다. 이 옵션을 끄면 이 기기(또는 브라우저)에서는 정적 이미지로만 표시됩니다."
+ }
+ },
+ "storedLayouts": {
+ "title": "저장된 레이아웃",
+ "desc": "카메라 그룹의 화면 배치는 드래그하거나 크기를 조정할 수 있습니다. 변경된 위치는 브라우저의 로컬 저장소에 저장됩니다.",
+ "clearAll": "레이아웃 지우기"
+ },
+ "cameraGroupStreaming": {
+ "title": "카메라 그룹 스트리밍 설정",
+ "desc": "각각의 카메라 그룹의 스트리밍 설정은 브라우저의 로컬 저장소에 저장됩니다.",
+ "clearAll": "스트리밍 설정 모두 지우기"
+ },
+ "recordingsViewer": {
+ "title": "녹화 영상 보기",
+ "defaultPlaybackRate": {
+ "label": "기본으로 설정된 다시보기 배속",
+ "desc": "다시보기 영상 재생할 때 기본 배속을 설정합니다."
+ }
+ },
+ "calendar": {
+ "title": "캘린더",
+ "firstWeekday": {
+ "label": "주 첫째날",
+ "desc": "다시보기 캘린더에서 주가 시작되는 첫째날을 설정합니다.",
+ "sunday": "일요일",
+ "monday": "월요일"
+ }
+ },
+ "toast": {
+ "success": {
+ "clearStoredLayout": "{{cameraName}}의 레이아웃을 지웠습니다",
+ "clearStreamingSettings": "모든 카메라 그룹 스트리밍 설정을 지웠습니다."
+ },
+ "error": {
+ "clearStoredLayoutFailed": "레이아웃 지우기에 실패했습니다:{{errorMessage}}",
+ "clearStreamingSettingsFailed": "카메라 스트리밍 설정 지우기에 실패했습니다:{{errorMessage}}"
+ }
+ }
+ },
+ "enrichments": {
+ "title": "고급 설정",
+ "unsavedChanges": "변경된 고급 설정을 저장하지 않았습니다"
+ }
+}
diff --git a/web/public/locales/ko/views/system.json b/web/public/locales/ko/views/system.json
index 0967ef424..4ed89d1ce 100644
--- a/web/public/locales/ko/views/system.json
+++ b/web/public/locales/ko/views/system.json
@@ -1 +1,186 @@
-{}
+{
+ "documentTitle": {
+ "cameras": "카메라 통계 - Frigate",
+ "storage": "저장소 통계 - Frigate",
+ "general": "기본 통계 - Frigate",
+ "enrichments": "고급 통계 - Frigate",
+ "logs": {
+ "frigate": "Frigate 로그 -Frigate",
+ "go2rtc": "Go2RTC 로그 - Frigate",
+ "nginx": "Nginx 로그 - Frigate"
+ }
+ },
+ "title": "시스템",
+ "metrics": "시스템 통계",
+ "logs": {
+ "download": {
+ "label": "다운로드 로그"
+ },
+ "copy": {
+ "label": "클립보드에 복사하기",
+ "success": "클립보드에 로그가 복사되었습니다",
+ "error": "클립보드에 로그를 저장할 수 없습니다"
+ },
+ "type": {
+ "label": "타입",
+ "timestamp": "시간 기록",
+ "tag": "태그",
+ "message": "메시지"
+ },
+ "tips": "서버에서 로그 스트리밍 중",
+ "toast": {
+ "error": {
+ "fetchingLogsFailed": "로그 가져오기 오류: {{errorMessage}}",
+ "whileStreamingLogs": "스크리밍 로그 중 오류: {{errorMessage}}"
+ }
+ }
+ },
+ "general": {
+ "title": "기본",
+ "detector": {
+ "title": "감지기",
+ "inferenceSpeed": "감지 추론 속도",
+ "temperature": "감지기 온도",
+ "cpuUsage": "감지기 CPU 사용률",
+ "memoryUsage": "감지기 메모리 사용률",
+ "cpuUsageInformation": "감지 모델로 데이터를 입력/출력하기 위한 전처리 과정에서 사용되는 CPU 사용량입니다. GPU나 가속기를 사용하는 경우에도 추론 자체의 사용량은 포함되지 않습니다."
+ },
+ "hardwareInfo": {
+ "title": "하드웨어 정보",
+ "gpuUsage": "GPU 사용률",
+ "gpuMemory": "GPU 메모리",
+ "gpuEncoder": "GPU 인코더",
+ "gpuDecoder": "GPU 디코더",
+ "gpuInfo": {
+ "vainfoOutput": {
+ "title": "Vainfo 출력",
+ "processOutput": "프로세스 출력:",
+ "processError": "프로세스 오류:",
+ "returnCode": "리턴 코드:{{code}}"
+ },
+ "nvidiaSMIOutput": {
+ "title": "Nvidia SMI 출력",
+ "name": "이름:{{name}}",
+ "driver": "드라이버:{{driver}}",
+ "cudaComputerCapability": "CUDA Compute Capability:{{cuda_compute}}",
+ "vbios": "VBios Info: {{vbios}}"
+ },
+ "copyInfo": {
+ "label": "GPU 정보 복사"
+ },
+ "toast": {
+ "success": "GPU 정보가 클립보드에 복사되었습니다"
+ },
+ "closeInfo": {
+ "label": "GPU 정보 닫기"
+ }
+ },
+ "npuUsage": "NPU 사용률",
+ "npuMemory": "NPU 메모리"
+ },
+ "otherProcesses": {
+ "title": "다른 프로세스들",
+ "processCpuUsage": "사용중인 CPU 사용률",
+ "processMemoryUsage": "사용중인 메모리 사용률"
+ }
+ },
+ "storage": {
+ "title": "스토리지",
+ "overview": "전체 현황",
+ "recordings": {
+ "title": "녹화",
+ "tips": "이 값은 Frigate 데이터베이스의 녹화 영상이 사용 중인 전체 저장 공간입니다. Frigate는 디스크 내 다른 파일들의 저장 공간은 추적하지 않습니다.",
+ "earliestRecording": "가장 오래된 녹화 영상:"
+ },
+ "cameraStorage": {
+ "title": "카메라 저장소",
+ "camera": "카메라",
+ "unusedStorageInformation": "미사용 저장소 정보",
+ "storageUsed": "용량",
+ "percentageOfTotalUsed": "전체 대비 비율",
+ "bandwidth": "대역폭",
+ "unused": {
+ "title": "미사용",
+ "tips": "드라이브에 Frigate 녹화 영상 외에 다른 파일이 저장되어 있는 경우, 이 값은 Frigate에서 실제 사용 가능한 여유 공간을 정확히 나타내지 않을 수 있습니다. Frigate는 녹화 영상 외의 저장 공간 사용량을 추적하지 않습니다."
+ }
+ },
+ "shm": {
+ "title": "SHM (공유 메모리) 할당량",
+ "warning": "현재 SHM 사이즈가 {{total}}MB로 너무 적습니다. 최소 {{min_shm}}MB 이상 올려주세요."
+ }
+ },
+ "cameras": {
+ "title": "카메라",
+ "overview": "전체 현황",
+ "info": {
+ "aspectRatio": "종횡비",
+ "fetching": "카메라 데이터 수집 중",
+ "stream": "스트림 {{idx}}",
+ "streamDataFromFFPROBE": "스트림 데이터는 ffprobe에서 받습니다.",
+ "video": "비디오:",
+ "codec": "코덱:",
+ "resolution": "해상도:",
+ "fps": "FPS:",
+ "unknown": "알 수 없음",
+ "audio": "오디오:",
+ "error": "오류:{{error}}",
+ "cameraProbeInfo": "{{camera}} 카메라 장치 정보",
+ "tips": {
+ "title": "카메라 장치 정보"
+ }
+ },
+ "framesAndDetections": "프레임 / 감지 (Detections)",
+ "label": {
+ "camera": "카메라",
+ "detect": "감지",
+ "skipped": "건너뜀",
+ "ffmpeg": "FFmpeg",
+ "capture": "캡쳐",
+ "overallFramesPerSecond": "전체 초당 프레임",
+ "overallDetectionsPerSecond": "전체 초당 감지",
+ "overallSkippedDetectionsPerSecond": "전체 초당 건너뛴 감지",
+ "cameraFfmpeg": "{{camName}} FFmpeg",
+ "cameraCapture": "{{camName}} 캡쳐",
+ "cameraDetect": "{{camName}} 감지",
+ "cameraFramesPerSecond": "{{camName}} 초당 프레임",
+ "cameraDetectionsPerSecond": "{{camName}} 초당 감지",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} 초당 건너뛴 감지"
+ },
+ "toast": {
+ "success": {
+ "copyToClipboard": "데이터 정보가 클립보드에 복사되었습니다."
+ },
+ "error": {
+ "unableToProbeCamera": "카메라 정보 알 수 없음: {{errorMessage}}"
+ }
+ }
+ },
+ "lastRefreshed": "마지막 새로고침: ",
+ "stats": {
+ "ffmpegHighCpuUsage": "{{camera}} FFmpeg CPU 사용량이 높습니다 ({{ffmpegAvg}}%)",
+ "detectHighCpuUsage": "{{camera}} 감지 CPU 사용량이 높습니다 ({{detectAvg}}%)",
+ "healthy": "시스템 정상",
+ "reindexingEmbeddings": "Reindexing embeddings ({{processed}}% complete)",
+ "cameraIsOffline": "{{camera}} 오프라인입니다",
+ "detectIsSlow": "{{detect}} (이/가) 느립니다 ({{speed}} ms)",
+ "detectIsVerySlow": "{{detect}} (이/가) 매우 느립니다 ({{speed}} ms)",
+ "shmTooLow": "/dev/shm 할당량을 ({{total}} MB) 최소 {{min}} MB 이상 증가시켜야합니다."
+ },
+ "enrichments": {
+ "title": "추가 분석 정보",
+ "infPerSecond": "초당 추론 속도",
+ "embeddings": {
+ "image_embedding": "이미지 임베딩",
+ "text_embedding": "텍스트 임베딩",
+ "face_recognition": "얼굴 인식",
+ "plate_recognition": "번호판 인식",
+ "image_embedding_speed": "이미지 임베딩 속도",
+ "face_embedding_speed": "얼굴 임베딩 속도",
+ "face_recognition_speed": "얼굴 인식 속도",
+ "plate_recognition_speed": "번호판 인식 속도",
+ "text_embedding_speed": "텍스트 임베딩 속도",
+ "yolov9_plate_detection_speed": "YOLOv9 플레이트 감지 속도",
+ "yolov9_plate_detection": "YOLOv9 플레이트 감지"
+ }
+ }
+}
diff --git a/web/public/locales/lt/audio.json b/web/public/locales/lt/audio.json
index 7f9bbc8a4..b9c772ee8 100644
--- a/web/public/locales/lt/audio.json
+++ b/web/public/locales/lt/audio.json
@@ -34,5 +34,470 @@
"laughter": "Juokas",
"snicker": "Kikenimas",
"crying": "Verkimas",
- "singing": "Dainavimas"
+ "singing": "Dainavimas",
+ "sigh": "Atodūsis",
+ "choir": "Choras",
+ "yodeling": "Jodliavimas",
+ "chant": "Giedojimas",
+ "mantra": "Mantra",
+ "child_singing": "Dainuoja Vaikas",
+ "synthetic_singing": "Netikras Dainavimas",
+ "rapping": "Repavimas",
+ "humming": "Dūzgimas",
+ "groan": "Dejuoti",
+ "grunt": "Niurzgėti",
+ "whistling": "Švilpti",
+ "breathing": "Kvepavimas",
+ "wheeze": "Švokštimas",
+ "snoring": "Knarkimas",
+ "gasp": "Aiktelėti",
+ "pant": "Kelnės",
+ "snort": "Knarkti",
+ "cough": "Kosėti",
+ "throat_clearing": "Atsikrenkšti",
+ "sneeze": "Čiaudėti",
+ "sniff": "Uostyti",
+ "run": "Bėgti",
+ "shuffle": "Maišyti",
+ "footsteps": "Žingsniai",
+ "chewing": "Kramtymas",
+ "biting": "Kandžiojimas",
+ "gargling": "Skalavimas",
+ "stomach_rumble": "Pilvo gurguliavimas",
+ "burping": "Atsirūgimas",
+ "hiccup": "Žaksėjimas",
+ "fart": "Bezdėjimas",
+ "hands": "Rankos",
+ "finger_snapping": "Spragsėjimas",
+ "clapping": "Plojimas",
+ "heartbeat": "Širdies plakimas",
+ "heart_murmur": "Širdies Ūžesys",
+ "cheering": "Džiūgavimas",
+ "applause": "Aplodismentai",
+ "chatter": "Plepėti",
+ "crowd": "Minia",
+ "children_playing": "Žaidžiantys Vaikai",
+ "pets": "Gyvūnai",
+ "yip": "Cyptelėjimas",
+ "howl": "Kaukimas",
+ "whimper_dog": "Šuns inkštimas",
+ "growling": "Urzgimas",
+ "bow_wow": "Au au",
+ "purr": "Murkimas",
+ "meow": "Miaukimas",
+ "hiss": "Šnypštimas",
+ "livestock": "Gyvuliai",
+ "caterwaul": "Kniaukimas",
+ "clip_clop": "Kanopų Kaukšėjimas",
+ "neigh": "Prunkštimas",
+ "moo": "Mūkimas",
+ "cattle": "Galvijai",
+ "cowbell": "Karvutės Varpelis",
+ "pig": "Kiaulė",
+ "oink": "Kriuksėjimas",
+ "bleat": "Bliovimas",
+ "chicken": "Višta",
+ "cock_a_doodle_doo": "Kakuriakuoti",
+ "cluck": "Kudakavimas",
+ "fowl": "Paukščiai",
+ "turkey": "Kalakutas",
+ "gobble": "Gargaliavimas",
+ "duck": "Antis",
+ "quack": "Kreksėjimas",
+ "goose": "Žąsis",
+ "wild_animals": "Laukiniai Gyvūnai",
+ "honk": "Gagenimas",
+ "roar": "Riaumoti",
+ "roaring_cats": "Riaumojančios Katės",
+ "pigeon": "Balandis",
+ "chirp": "Čiulbėti",
+ "crow": "Varna",
+ "squawk": "Klykimas",
+ "coo": "Ku",
+ "owl": "Pelėda",
+ "caw": "Kranksėjimas",
+ "hoot": "Ūkti",
+ "flapping_wings": "Sparnų plazdėjimas",
+ "dogs": "Šunys",
+ "rats": "Žiurkės",
+ "insect": "Vabzdžiai",
+ "cricket": "Svirpliai",
+ "mosquito": "Uodai",
+ "fly": "Musės",
+ "buzz": "Užėsys",
+ "patter": "Tekšėjimas",
+ "frog": "Varlė",
+ "snake": "Gyvatė",
+ "croak": "Kvarksėti",
+ "rattle": "Barškėti",
+ "whale_vocalization": "Banginio Įgarsinimas",
+ "music": "Muzika",
+ "musical_instrument": "Muzikinis Instrumentas",
+ "plucked_string_instrument": "Sugedęs Styginis Instrumentas",
+ "guitar": "Gitara",
+ "electric_guitar": "Elektrinė Gitara",
+ "bass_guitar": "Bosinė Gitara",
+ "acoustic_guitar": "Akustinė Gitara",
+ "steel_guitar": "Metalinė Gitara",
+ "sitar": "Sitara",
+ "mandolin": "Mandolina",
+ "ukulele": "Ukulėle",
+ "piano": "Pianinas",
+ "electric_piano": "Elektrinis pianinas",
+ "organ": "Vargonai",
+ "banjo": "Bandžia",
+ "scream": "Rėkti",
+ "field_recording": "Įrašinėjimas lauke",
+ "radio": "Radijas",
+ "television": "Televizija",
+ "white_noise": "Baltasis triukšmas",
+ "pink_noise": "Rožinis triukšmas",
+ "silence": "Tyla",
+ "shatter": "Dūžimas",
+ "glass": "Stiklas",
+ "crack": "Trūkimas",
+ "wood": "Medis",
+ "chop": "Kapojimas",
+ "boom": "Bumtėlti",
+ "eruption": "Išsiveržimas",
+ "fireworks": "Fejerverkai",
+ "artillery_fire": "Artilerinė ugnis",
+ "explosion": "Sprogimas",
+ "drill": "Grežimas",
+ "sanding": "Šveisti",
+ "power_tool": "Elektriniai įrankiai",
+ "machine_gun": "Kulkosvaidis",
+ "filing": "Dildinti",
+ "sawing": "Pjauti",
+ "jackhammer": "Kūjis",
+ "hammer": "Plaktukas",
+ "tools": "Įrankiai",
+ "printer": "Spausdintuvas",
+ "cash_register": "Kasos Aparatas",
+ "air_conditioning": "Oro Kondicionavimas",
+ "sewing_machine": "Siuvimo Mašina",
+ "pulleys": "Skriemulys",
+ "gears": "Dantračiai",
+ "tick-tock": "Tiksėjimas",
+ "tick": "Tik",
+ "mechanisms": "Mechanizmas",
+ "whistle": "Švilpimas",
+ "steam_whistle": "Garinis Švilpimas",
+ "fire_alarm": "Gaistro Signalas",
+ "smoke_detector": "Dūmų detektorius",
+ "siren": "Sirena",
+ "alarm_clock": "Žadintuvas",
+ "telephone": "Telefonas",
+ "writing": "Rašymas",
+ "shuffling_cards": "Kortų Maišymas",
+ "zipper": "Užtrauktukas",
+ "electric_toothbrush": "Elektrinis Dantų Šepetėlis",
+ "tapping": "Tapsėjimas",
+ "strum": "Brazdėjimas",
+ "electronic_organ": "Elektriniai Vargonai",
+ "hammond_organ": "Hammond Vargonai",
+ "synthesizer": "Sintezatorius",
+ "sampler": "Sampleris",
+ "harpsichord": "Fortepionas",
+ "percussion": "Perkusija",
+ "drum_kit": "Būgnų Rinkinys",
+ "drum_machine": "Būgnų Mašina",
+ "drum": "Būgnas",
+ "snare_drum": "Snare Būgnas",
+ "timpani": "Timpanas",
+ "tabla": "Tabla",
+ "cymbal": "Cimbala",
+ "hi_hat": "Lėkštės",
+ "wood_block": "Medienos Lentgalis",
+ "tambourine": "Tamburinas",
+ "maraca": "Maraka",
+ "gong": "Gongas",
+ "tubular_bells": "Vamzdiniai Varpeliai",
+ "mallet_percussion": "Malet Perkusija",
+ "vibraphone": "Vibrafonas",
+ "steelpan": "Metalinė Lėkštė",
+ "orchestra": "Orkestras",
+ "brass_instrument": "Variniai Instrumentai",
+ "trombone": "Trombonas",
+ "string_section": "Stygų Sekcija",
+ "violin": "Smuikas",
+ "double_bass": "Dvigubas Bosas",
+ "wind_instrument": "Vėjo Instrumentas",
+ "flute": "Fleita",
+ "saxophone": "Saksofonas",
+ "clarinet": "Klarnetas",
+ "bell": "Varpas",
+ "church_bell": "Bažnyčios Varpas",
+ "jingle_bell": "Kalėdinis Varpelis",
+ "bicycle_bell": "Dviračio Skambutis",
+ "tuning_fork": "Derinimo Šakutė",
+ "chime": "Skambesys",
+ "wind_chime": "Vėjo Skambesys",
+ "harmonica": "Lūpinė armonika",
+ "accordion": "Akordionas",
+ "bagpipes": "Dūdmaišis",
+ "pop_music": "Pop Muzika",
+ "hip_hop_music": "Hip-Hop Muzika",
+ "beatboxing": "Beatboksingas",
+ "rock_music": "Roko Muzika",
+ "heavy_metal": "Sunkusis Metalas",
+ "punk_rock": "Pank Rokas",
+ "progressive_rock": "Progresyvus Rokas",
+ "rock_and_roll": "Rokenrolas",
+ "psychedelic_rock": "Psichodelinis Rokas",
+ "rhythm_and_blues": "Ritmbliuzas",
+ "reggae": "Regis",
+ "swing_music": "Swingas",
+ "folk_music": "Liaudies Muzikas",
+ "middle_eastern_music": "Viduriniųjų Rytų Muzika",
+ "jazz": "Jazas",
+ "disco": "Disko",
+ "classical_music": "Klasikinė Muzika",
+ "opera": "Opera",
+ "electronic_music": "Elektroninė Muzika",
+ "house_music": "House Muzika",
+ "techno": "Techno",
+ "dubstep": "Dubstepas",
+ "electronica": "Elektroninė",
+ "electronic_dance_music": "Elektroninė Šokių Muzika",
+ "trance_music": "Transo Muzika",
+ "music_of_latin_america": "Lotynų Amerikos Muzika",
+ "salsa_music": "Salsa Muzika",
+ "flamenco": "Flamenko",
+ "blues": "Bliuzas",
+ "music_for_children": "Vaikų Muzika",
+ "vocal_music": "Vokalinė Muzika",
+ "a_capella": "Akapela",
+ "music_of_africa": "Afrikietiška Muzika",
+ "christian_music": "Krikščioniška Muzika",
+ "gospel_music": "Gospelo Muzika",
+ "music_of_asia": "Azijietiška Muzika",
+ "music_of_bollywood": "Bolivudo Muzika",
+ "traditional_music": "Tradicinė Muzika",
+ "song": "Daina",
+ "background_music": "Foninė Muzika",
+ "theme_music": "Teminė Muzika",
+ "jingle": "Džinglas",
+ "soundtrack_music": "Garsotakelio Muzika",
+ "lullaby": "Lopšinė",
+ "video_game_music": "Video Žaidimų Muzika",
+ "christmas_music": "Kalėdinė Muzika",
+ "dance_music": "Šokių Muzika",
+ "wedding_music": "Vestuvinė Muzika",
+ "sad_music": "Liūdna Muzika",
+ "happy_music": "Laiminga Muzika",
+ "angry_music": "Pikta Muzika",
+ "scary_music": "Gązdinanti Muzika",
+ "wind": "Vėjas",
+ "rustling_leaves": "Šlamantys Lapai",
+ "wind_noise": "Vėjo Švilpimas",
+ "thunderstorm": "Perkūnija",
+ "thunder": "Griaustinis",
+ "water": "Vanduo",
+ "rain": "Lietus",
+ "raindrop": "Lietaus Lašai",
+ "rain_on_surface": "Lija ant Paviršiaus",
+ "stream": "Srovė",
+ "waterfall": "Krioklys",
+ "ocean": "Okeanas",
+ "waves": "Bangos",
+ "steam": "Garai",
+ "gurgling": "Gurguliavimas",
+ "fire": "Ugnis",
+ "crackle": "Spragėjimas",
+ "sailboat": "Burlaivis",
+ "rowboat": "Irklinė valtis",
+ "motorboat": "Motorinė Valtis",
+ "ship": "Laivas",
+ "motor_vehicle": "Motorinis Transportas",
+ "car_alarm": "Mašinos Signalizacija",
+ "power_windows": "Elektriniai Langai",
+ "tire_squeal": "Padangų cypimas",
+ "car_passing_by": "Pravažiuojanti Mašina",
+ "race_car": "Lenktyninė Mašina",
+ "truck": "Sunkvežimis",
+ "air_brake": "Oro Stabdis",
+ "reversing_beeps": "Atbulinės Eigos Signalas",
+ "ice_cream_truck": "Ledų Mašina",
+ "emergency_vehicle": "Pagalbos Transportas",
+ "police_car": "Policijos Mašina",
+ "ambulance": "Greitoji",
+ "fire_engine": "Užvesti Variklis",
+ "traffic_noise": "Esimo Triukšmas",
+ "train_whistle": "Traukinio Švilpimas",
+ "train_horn": "Traukinio Pypsėjimas",
+ "subway": "Metro",
+ "aircraft": "Orlaivis",
+ "aircraft_engine": "Orlaivio Variklis",
+ "jet_engine": "Reaktyvinis Variklis",
+ "propeller": "Propeleris",
+ "helicopter": "Malūnsparnis",
+ "fixed-wing_aircraft": "Fiksuotų Sparnų Orlaivis",
+ "engine": "Variklis",
+ "light_engine": "Mažas Variklis",
+ "dental_drill's_drill": "Dantų Gręžimas",
+ "lawn_mower": "Žoliapjovė",
+ "chainsaw": "Grandininis Pjūklas",
+ "medium_engine": "Vidutinis Variklis",
+ "heavy_engine": "Didelis Variklis",
+ "engine_knocking": "Variklio Kalimas",
+ "engine_starting": "Užsikuriantis Variklis",
+ "idling": "Laisvai Dirbantis",
+ "accelerating": "Įsibegėjantis",
+ "doorbell": "Dūrų Skambutis",
+ "sliding_door": "Slankiojančios Durys",
+ "slam": "Trenkti",
+ "knock": "Stuksėti",
+ "tap": "Tapšnoti",
+ "cupboard_open_or_close": "Spintelė Atidaryti ar Užsidaryti",
+ "drawer_open_or_close": "Stalčių Atidaryti ar Uždaryti",
+ "dishes": "Indai",
+ "cutlery": "Stalo Įrankiai",
+ "chopping": "Kapoti",
+ "static": "Statinis",
+ "environmental_noise": "Aplinkos Triukšmas",
+ "sound_effect": "Garso efektai",
+ "firecracker": "Ugnies Spragėjimas",
+ "gunshot": "Ginklo Šūvis",
+ "single-lens_reflex_camera": "Veidrodinis Fotoparatas",
+ "mechanical_fan": "Mechaninis Fenas",
+ "ratchet": "Raketė",
+ "civil_defense_siren": "Civilinės Saugos Sirena",
+ "busy_signal": "Užimtas Signalas",
+ "dial_tone": "Numerio Rinkimo Tonas",
+ "telephone_dialing": "Telefono Rinkimas",
+ "ringtone": "Skambėjimo Tonas",
+ "telephone_bell_ringing": "Skamba Telefonas",
+ "alarm": "Signalizacija",
+ "computer_keyboard": "Kopiuterio Klaviatūra",
+ "typewriter": "Spausdinimo Mašina",
+ "typing": "Spausdinti",
+ "electric_shaver": "Barzdaskutė",
+ "coin": "Moneta",
+ "keys_jangling": "Žvangantys Raktai",
+ "vacuum_cleaner": "Siurblys",
+ "toilet_flush": "Tualeto Nuleidimas",
+ "bathtub": "Vonia",
+ "water_tap": "Vandens Kranas",
+ "microwave_oven": "Mikorbangų Krosnelė",
+ "frying": "Gruzdinimas",
+ "zither": "Citara",
+ "rimshot": "Mušimas per kraštą",
+ "drum_roll": "Būgno dundesys",
+ "bass_drum": "Bosinis Būgnas",
+ "marimba": "Marimba",
+ "glockenspiel": "Varpelis",
+ "french_horn": "Prancūzų Ragas",
+ "trumpet": "Trimitas",
+ "bowed_string_instrument": "Styginiai Instrumentai",
+ "pizzicato": "Pizikatas",
+ "cello": "Violončelė",
+ "harp": "Arfa",
+ "didgeridoo": "Didžeridū",
+ "theremin": "Tereminas",
+ "singing_bowl": "Dainuojantis Dubuo",
+ "scratching": "Skrečavimas",
+ "grunge": "Grandžas",
+ "soul_music": "Soul Muzika",
+ "country": "Country Muzika",
+ "bluegrass": "Bluegrass",
+ "funk": "Funk",
+ "drum_and_bass": "Drum & Bass",
+ "ambient_music": "Ambient Muzika",
+ "new-age_music": "Naujojo Amžiaus Muzika",
+ "afrobeat": "Afrikietiški Ritmai",
+ "carnatic_music": "Karnatietiška Muzika",
+ "ska": "Ska",
+ "independent_music": "Nepriklausoma Muzika",
+ "tender_music": "Švelni Muzika",
+ "exciting_music": "Jaudinanti Muzika",
+ "toot": "Pyptelėjimas",
+ "skidding": "Slydimas",
+ "air_horn": "Klaksonas",
+ "rail_transport": "Bėginis Transportas",
+ "railroad_car": "Geležinkelio Vagonas",
+ "train_wheels_squealing": "Cypiantys Traukino Ratai",
+ "ding-dong": "Ding-Dong",
+ "squeak": "Cypimas",
+ "buzzer": "Skambutis",
+ "foghorn": "Rūko Sirena",
+ "fusillade": "Šaudymas",
+ "cap_gun": "Kapsulinis Pistoletas",
+ "burst": "Sprogimas",
+ "splinter": "Skeveldra",
+ "chink": "Skambėjimas",
+ "sodeling": "Sodliavimas",
+ "chird": "Akordai",
+ "change_ringing": "Kintantis Skambinimas",
+ "shofar": "Šofaras",
+ "liquid": "Skystis",
+ "splash": "Pliūpsnis",
+ "slosh": "Telkšo",
+ "squish": "Šliurpti",
+ "drip": "Kapsi",
+ "pour": "Pilasi",
+ "trickle": "Sruvenimas",
+ "gush": "Plūstelėjimas",
+ "fill": "Pildyti",
+ "spray": "Purkšti",
+ "pump": "Siurbti",
+ "stir": "Makaluoti",
+ "boiling": "Virimas",
+ "sonar": "Sonaras",
+ "arrow": "Strėlė",
+ "whoosh": "Užt",
+ "thump": "Bumpt",
+ "thunk": "Tunkt",
+ "electronic_tuner": "Elektroninis Imtuvas",
+ "effects_unit": "Efektų Mašina",
+ "chorus_effect": "Chorinis Efektas",
+ "basketball_bounce": "Krepšinio Kamuolio Atšokimas",
+ "bang": "Trenksmas",
+ "slap": "Plaukštelėjimas",
+ "whack": "Kirtis",
+ "smash": "Tėkšti",
+ "breaking": "Lūžtantis",
+ "bouncing": "Atsimušinėjimas",
+ "whip": "Vykšt",
+ "flap": "Klapt",
+ "scratch": "Braižyti",
+ "scrape": "Gramdyti",
+ "rub": "Trinti",
+ "roll": "Vynioti",
+ "crushing": "Traiškymas",
+ "crumpling": "Glamžymas",
+ "tearing": "Trinasi",
+ "beep": "Pypt",
+ "ping": "Pingsi",
+ "ding": "Dingsi",
+ "clang": "Klenga",
+ "squeal": "Žviegimas",
+ "creak": "Girgžt",
+ "rustle": "Šlamėjimas",
+ "whir": "Ūžimas",
+ "clatter": "Klapsėjimas",
+ "sizzle": "Čirškėjimas",
+ "clicking": "Spaksėjimas",
+ "clickety_clack": "Klaukšėjimas",
+ "rumble": "Dundėjimas",
+ "plop": "Plapsėjimas",
+ "hum": "Zyzimas",
+ "zing": "Zinga",
+ "boing": "Blyngt",
+ "crunch": "Trekšt",
+ "sine_wave": "Sinuso Banga",
+ "harmonic": "Harmoniškas",
+ "chirp_tone": "Svirpiantis Tonas",
+ "pulse": "Pusluojantis",
+ "inside": "Viduje",
+ "outside": "Išorėje",
+ "reverberation": "Atgarsis",
+ "echo": "Aidas",
+ "noise": "Triukšmas",
+ "mains_hum": "Įvado užesys",
+ "distortion": "Iškraipymai",
+ "sidetone": "Šalutinis tonas",
+ "cacophony": "Kokofonija",
+ "throbbing": "Frobingas",
+ "vibration": "Vibracija"
}
diff --git a/web/public/locales/lt/common.json b/web/public/locales/lt/common.json
index 0f512e147..7f2927ffd 100644
--- a/web/public/locales/lt/common.json
+++ b/web/public/locales/lt/common.json
@@ -47,20 +47,69 @@
"second_few": "{{time}} sekundės",
"second_other": "{{time}} sekundžių",
"formattedTimestamp": {
- "12hour": ""
- }
+ "12hour": "MMM d, h:mm:ss aaa",
+ "24hour": "MMM d, HH:mm:ss"
+ },
+ "formattedTimestamp2": {
+ "12hour": "MM/dd h:mm:ssa",
+ "24hour": "d MMM HH:mm:ss"
+ },
+ "formattedTimestampHourMinute": {
+ "12hour": "h:mm aaa",
+ "24hour": "HH:mm"
+ },
+ "formattedTimestampHourMinuteSecond": {
+ "12hour": "h:mm:ss aaa",
+ "24hour": "HH:mm:ss"
+ },
+ "formattedTimestampMonthDayHourMinute": {
+ "12hour": "MMM d, h:mm aaa",
+ "24hour": "MMM d, HH:mm"
+ },
+ "formattedTimestampMonthDayYear": {
+ "12hour": "MMM d, yyyy",
+ "24hour": "MMM d, yyyy"
+ },
+ "formattedTimestampMonthDayYearHourMinute": {
+ "12hour": "MMM d yyyy, h:mm aaa",
+ "24hour": "MMM d yyyy, HH:mm"
+ },
+ "formattedTimestampMonthDay": "MMM d",
+ "formattedTimestampFilename": {
+ "12hour": "MM-dd-yy-h-mm-ss-a",
+ "24hour": "MM-dd-yy-HH-mm-ss"
+ },
+ "inProgress": "Apdorojama",
+ "invalidStartTime": "Netinkamas pradžios laikas",
+ "invalidEndTime": "Netinkamas pabaigos laikas",
+ "never": "Niekada"
},
"unit": {
"speed": {
- "kph": "kmh"
+ "kph": "kmh",
+ "mph": "mph"
},
"length": {
"feet": "pėdos",
"meters": "metrai"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/val",
+ "mbph": "MB/val",
+ "gbph": "GB/val"
}
},
"label": {
- "back": "Eiti atgal"
+ "back": "Eiti atgal",
+ "hide": "Slėpti {{item}}",
+ "show": "Rodyti {{item}}",
+ "ID": "ID",
+ "none": "Nėra",
+ "all": "Visi",
+ "other": "Kiti"
},
"button": {
"apply": "Pritaikyti",
@@ -82,21 +131,23 @@
"pictureInPicture": "Paveikslėlis Paveiksle",
"twoWayTalk": "Dvikryptis Kalbėjimas",
"cameraAudio": "Kameros Garsas",
- "on": "",
+ "on": "ON",
"edit": "Redaguoti",
"copyCoordinates": "Kopijuoti koordinates",
"delete": "Ištrinti",
"yes": "Taip",
"no": "Ne",
"download": "Atsisiųsti",
- "info": "",
+ "info": "Info",
"suspended": "Pristatbdytas",
"unsuspended": "Atnaujinti",
"play": "Groti",
"unselect": "Atžymėti",
"export": "Eksportuoti",
"deleteNow": "Trinti Dabar",
- "next": "Kitas"
+ "next": "Kitas",
+ "off": "OFF",
+ "continue": "Tęsti"
},
"menu": {
"system": "Sistema",
@@ -131,10 +182,24 @@
"hu": "Vengrų",
"fi": "Suomių",
"da": "Danų",
- "sk": "Slovėnų",
+ "sk": "Slovakų",
"withSystem": {
"label": "Kalbai naudoti sistemos nustatymus"
- }
+ },
+ "hi": "Hindi",
+ "ptBR": "Brazilietiška Portugalų",
+ "ko": "Korėjiečių",
+ "he": "Hebrajų",
+ "yue": "Kantoniečių",
+ "th": "Tailandiečių",
+ "ca": "Kataloniečių",
+ "sr": "Serbų",
+ "sl": "Slovėnų",
+ "lt": "Lietuvių",
+ "bg": "Bulgarų",
+ "gl": "Galician",
+ "id": "Indonesian",
+ "ur": "Urdu"
},
"appearance": "Išvaizda",
"darkMode": {
@@ -182,7 +247,9 @@
"anonymous": "neidentifikuotas",
"logout": "atsijungti",
"setPassword": "Nustatyti Slaptažodi"
- }
+ },
+ "uiPlayground": "UI Playground",
+ "classification": "Klasifikavimas"
},
"toast": {
"copyUrlToClipboard": "URL nukopijuotas į atmintį.",
@@ -209,6 +276,31 @@
"next": {
"title": "Sekantis",
"label": "Eiti į sekantį puslapį"
- }
+ },
+ "more": "Daugiau puslapių"
+ },
+ "accessDenied": {
+ "documentTitle": "Priegai Nesuteikta - Frigate",
+ "title": "Prieiga Nesuteikta",
+ "desc": "Jūs neturite leidimo žiūrėti šį puslapį."
+ },
+ "notFound": {
+ "documentTitle": "Nerasta - Frigate",
+ "title": "404",
+ "desc": "Puslapis nerastas"
+ },
+ "selectItem": "Pasirinkti {{item}}",
+ "readTheDocumentation": "Skaityti dokumentaciją",
+ "information": {
+ "pixels": "{{area}}px"
+ },
+ "list": {
+ "two": "{{0}} ir {{1}}",
+ "many": "{{items}}, ir {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Pasirinktinis",
+ "internalID": "Vidinį ID Frigate naudoja konfiguracijoje ir duombazėje"
}
}
diff --git a/web/public/locales/lt/components/auth.json b/web/public/locales/lt/components/auth.json
index 7b3737040..3ba7d103b 100644
--- a/web/public/locales/lt/components/auth.json
+++ b/web/public/locales/lt/components/auth.json
@@ -10,6 +10,7 @@
"loginFailed": "Prisijungti nepavyko",
"unknownError": "Nežinoma klaida. Patikrinkite įrašus.",
"webUnknownError": "Nežinoma klaida. Patikrinkite konsolės įrašus."
- }
+ },
+ "firstTimeLogin": "Bandote prisijungti pirmą kartą? Prisijungimo informaciją rasite Frigate loguose."
}
}
diff --git a/web/public/locales/lt/components/camera.json b/web/public/locales/lt/components/camera.json
index 11639ade2..2e3ef8a87 100644
--- a/web/public/locales/lt/components/camera.json
+++ b/web/public/locales/lt/components/camera.json
@@ -7,7 +7,7 @@
"label": "Ištrinti Kamerų Grupę",
"confirm": {
"title": "Patvirtinti ištrynimą",
- "desc": "Ar tikrai norite ištrinti šią kamerų grupę {{name}}?"
+ "desc": "Esate įsitikinę, kad norite ištrinti šią kamerų grupę {{name}}?"
}
},
"name": {
@@ -15,8 +15,73 @@
"placeholder": "Įveskite pavadinimą…",
"errorMessage": {
"mustLeastCharacters": "Kamerų grupės pavadinimas turi būti bent 2 simbolių.",
- "exists": "Kamerų grupės pavadinimas jau egzistuoja."
+ "exists": "Kamerų grupės pavadinimas jau egzistuoja.",
+ "nameMustNotPeriod": "Kamerų grupės pavadinime negali būti taško.",
+ "invalid": "Nepriimtinas kamera grupės pavadinimas."
}
+ },
+ "cameras": {
+ "label": "Kameros",
+ "desc": "Pasirinkite kameras šiai grupei."
+ },
+ "icon": "Ikona",
+ "success": "Kameraų grupė {{name}} išsaugota.",
+ "camera": {
+ "setting": {
+ "label": "Kamerų Transliacijos Nustatymai",
+ "title": "{{cameraName}} Transliavimo Nustatymai",
+ "desc": "Keisti tiesioginės tranliacijos nustatymus šiai kamerų grupės valdymo lentai. Šie nustatymai yra specifiniai įrenginiui/ naršyklei.",
+ "audioIsAvailable": "Šiai transliacijai yra garso takelis",
+ "audioIsUnavailable": "Šiai transliacijai nėra garso takelio",
+ "audio": {
+ "tips": {
+ "title": "Šiai transliacijai garsas turi būti teikiamas iš kameros ir konfiguruojamas naudojant go2rtc.",
+ "document": "Skaityti dokumentaciją "
+ }
+ },
+ "stream": "Transliacija",
+ "placeholder": "Pasirinkti transliaciją",
+ "streamMethod": {
+ "label": "Transliacijos Metodas",
+ "placeholder": "Pasirinkti transliacijos metodą",
+ "method": {
+ "noStreaming": {
+ "label": "Nėra transliacijos",
+ "desc": "Kameros vaizdas atsinaujins tik kartą per mintuę ir nebus tiesioginės transliacijos."
+ },
+ "smartStreaming": {
+ "label": "Išmanus Transliavimas (rekomenduojama)",
+ "desc": "Išmanus transliavimas atnaujins jūsų kameros vaizdą kartą per minutę jei nebus aptinkama jokia veikla tam kad saugoti tinklo pralaiduma ir kitus resursus. Aptikus veiklą atvaizdavimas nepertraukiamai persijungs į tiesioginę transliaciją."
+ },
+ "continuousStreaming": {
+ "label": "Nuolatinė Transliacija",
+ "desc": {
+ "title": "Kameros vaizdas visada bus tiesioginė transliacija, jei jis bus matomas valdymo lentoje, net jei jokia veikla nėra aptinkama.",
+ "warning": "Nepertraukiama transliacija gali naudoti daug tinklo duomenų bei sukelti našumo problemų. Naudoti su atsarga."
+ }
+ }
+ }
+ },
+ "compatibilityMode": {
+ "desc": "Šį nustatymą naudoti tik jei jūsų kameros tiesioginėje transliacijoje matomi spalvų neatitikimai arba matoma įstriža linija dešinėje vaizdo pusėje.",
+ "label": "Suderinamumo rėžimas"
+ }
+ },
+ "birdseye": "Birdseye"
}
+ },
+ "debug": {
+ "options": {
+ "label": "Nustatymai",
+ "title": "Pasirinkimai",
+ "showOptions": "Rodyti Pasirinkimus",
+ "hideOptions": "Slėpti Pasirinkimus"
+ },
+ "boundingBox": "Apribojantis Stačiakampis",
+ "timestamp": "Laiko žymė",
+ "zones": "Zonos",
+ "mask": "Maskuotė",
+ "motion": "Judesys",
+ "regions": "Regionas"
}
}
diff --git a/web/public/locales/lt/components/dialog.json b/web/public/locales/lt/components/dialog.json
index 4feb8d583..ae5760132 100644
--- a/web/public/locales/lt/components/dialog.json
+++ b/web/public/locales/lt/components/dialog.json
@@ -1,6 +1,6 @@
{
"restart": {
- "title": "Ar įsitikinę kad norite perkrauti Frigate?",
+ "title": "Esate įsitikinę, kad norite perkrauti Frigate?",
"button": "Perkrauti",
"restarting": {
"title": "Frigate Persikrauna",
@@ -14,12 +14,110 @@
"question": {
"ask_a": "Ar šis objektas yra {{label}}?",
"ask_an": "Ar šis objektas yra {{label}}?",
- "label": "Patvirtinti šią etiketę į Frigate Plus"
+ "label": "Patvirtinti šią etiketę į Frigate Plus",
+ "ask_full": "Ar šis objektas yra {{untranslatedLabel}} ({{translatedLabel}})?"
+ },
+ "state": {
+ "submitted": "Pateikta"
}
},
"submitToPlus": {
- "label": "Pateiktį į Frigate+"
+ "label": "Pateiktį į Frigate+",
+ "desc": "Objektai vietose kurių norite vengti nėra klaidingai teigiami. Pateikiant juos kaip klaidingai teigiamus įneš neatitikimų į modelį."
+ }
+ },
+ "video": {
+ "viewInHistory": "Pažiūrėti Istorijoje"
+ }
+ },
+ "streaming": {
+ "restreaming": {
+ "disabled": "Šiai kamerai pertransliavimas nėra įjungtas.",
+ "desc": {
+ "title": "Nustatyti go2rtc papildomoms tiesioginės transliacijos galimybėms ir šios kameros garsui."
+ }
+ },
+ "label": "Srautas",
+ "showStats": {
+ "label": "Rodyti transliacijos statistiką",
+ "desc": "Įjungti šią galimybę rodyti transliacijos statistiką kaip pridėtinę informaciją kameros vaizde."
+ },
+ "debugView": "Debug Vaizdas"
+ },
+ "export": {
+ "time": {
+ "lastHour_one": "Paskutinė {{count}} Valanda",
+ "lastHour_few": "Paskutinės {{count}} Valandos",
+ "lastHour_other": "Paskutinės {{count}} Valandų",
+ "fromTimeline": "Pasirinkit iš Laiko juostos",
+ "custom": "Pasirinkimas",
+ "start": {
+ "title": "Pradžios Laikas",
+ "label": "Pasirinkti Pradžios Laiką"
+ },
+ "end": {
+ "title": "Pabaigos Laikas",
+ "label": "Pasirinkti Pabaigos Laiką"
+ }
+ },
+ "fromTimeline": {
+ "previewExport": "Peržiūrėti Eksportuotus",
+ "saveExport": "Išsaugoti Exportuojamą"
+ },
+ "name": {
+ "placeholder": "Pavadinti eksportuojamą įrašą"
+ },
+ "select": "Pasirinkti",
+ "export": "Eksportuoti",
+ "selectOrExport": "Pasirinkti ar Eksportuoti",
+ "toast": {
+ "success": "Sėkmingai pradėtas eksportavimas. Peržiūrėti įrašą exports puslapyje.",
+ "error": {
+ "failed": "Nepavyko pradėti eksportavimo: {{error}}",
+ "endTimeMustAfterStartTime": "Pabaigos Laikas privalo būti vėliau nei pradžios laikas",
+ "noVaildTimeSelected": "Nėra pasirinkto tinkamo laikotarpio"
+ },
+ "view": "Žiūrėti"
+ }
+ },
+ "recording": {
+ "button": {
+ "markAsReviewed": "Žymėti kaip peržiūrėtą",
+ "export": "Eksportuoti",
+ "deleteNow": "Ištrinti Dabar",
+ "markAsUnreviewed": "Pažymėti kaip nematytą"
+ },
+ "confirmDelete": {
+ "desc": {
+ "selected": "Ar esate įsitikinę, kad norite ištrinti visus įrašytus vaizdo įrašus susijusius su šiuo peržiūros elementu?annotation_offset reikšmė gali būti naudojama tai koreguoti.",
+ "millisecondsToOffset": "Praslinkti aptikimų anotacijas per mili-sekundes. Bazinis: 0",
+ "label": "Anotacijos Perstūmimas",
+ "tips": "Patarimas: Įsivaizduokite kad yra įvykio klipas kur žmogus eina iš kairės į dešinę. Jei apibrėžimo dėžutė nuolatos yra žmogui iš kairės tuomet reikšmę sumažinkite. Analogiškai, jei dėžutė piešiama priekyje žmogaus tuomet reikšmę padidinkite.",
+ "toast": {
+ "success": "Anotacijos perslinkimas kamerai {{camera}} buvo išsaugota konfiguracijoje. Perkraukite Frigate, kad pritaikytumėte pokyčius."
+ }
+ },
+ "title": "Anotacijų Nustatymai",
+ "showAllZones": {
+ "title": "Rodyti Visas Zonas",
+ "desc": "Visada rodyti zonas tuose kadruose, kuriuose objektas pateko į zoną."
+ }
+ },
+ "title": "Objekto Gyvavimo Ciklas",
+ "noImageFound": "Šiam laikotarpiui vaizdų nerasta.",
+ "createObjectMask": "Sukurta Objekto Maskuotė",
+ "adjustAnnotationSettings": "Koreguoti anotacijų nustatymus",
+ "scrollViewTips": "Peržiūrėti šio objekto gyvavimo cikle esančius reikšmingus momentus.",
+ "autoTrackingTips": "Automatiškai sekančių kamerų apibrėžiančios dėžutės pozicija bus netiksli.",
+ "count": "{{first}} iš {{second}}",
+ "trackedPoint": "Sekamas Taškas",
+ "carousel": {
+ "previous": "Ankstesnė skaidrė",
+ "next": "Sekanti skaidrė"
+ }
+ },
+ "dialog": {
+ "confirmDelete": {
+ "desc": "Trinant šį sekamą objektą taip pat bus pašalintos momentinės iškarpos, išsaugoti įterpiai ir kitos susios sekimo detalės. Šių sekamų objektų įrašyta filmuota medžiaga Istorijos vaizde ištrinta NEBUS.rėžime: {{effectiveRetainMode}}, taigi įrašai pagal poreikį irgi bus saugomi pritaikant {{effectiveRetainModeName}}."
+ },
+ "editLayout": {
+ "label": "Redaguoti Išdėstymą",
+ "group": {
+ "label": "Redaguoti Kamerų Grupę"
+ },
+ "exitEdit": "Išeiti Iš Redagavimo"
+ },
+ "noCameras": {
+ "title": "Nėra Sukonfiguruotų Kamerų",
+ "description": "Pradėti nuo kameros prijungimo pire Frigate.",
+ "buttonText": "Pridėti Kamerą",
+ "restricted": {
+ "title": "Nėra Prieinamų Kamerų",
+ "description": "Jūs neturite leidimo matyti kameras šioje grupėje."
+ },
+ "default": {
+ "title": "Nėra Sukonfiguruotų Kamerų",
+ "description": "Pradėkite nuo kameros prijungimo prie Frigate.",
+ "buttonText": "Pridėti Kamerą"
+ },
+ "group": {
+ "title": "Grupėje Kamerų Nėra",
+ "description": "Ši kamerų grupė neturi priskirtų ar įjungtų kamerų.",
+ "buttonText": "Valdyti Grupes"
+ }
+ },
+ "snapshot": {
+ "takeSnapshot": "Atsisiųsti momentinį kadrą",
+ "noVideoSource": "Momentinei nuotraukai nėra prieinamo video šaltinio.",
+ "captureFailed": "Nepavyko užfiksuoti kadro.",
+ "downloadStarted": "Momentinės nuotraukos atsisiuntimas pradėtas."
}
}
diff --git a/web/public/locales/lt/views/search.json b/web/public/locales/lt/views/search.json
index d970b3d2d..eac3b4f55 100644
--- a/web/public/locales/lt/views/search.json
+++ b/web/public/locales/lt/views/search.json
@@ -12,7 +12,62 @@
"trackedObjectId": "Sekamo Objekto ID",
"filter": {
"label": {
- "cameras": "Kameros"
+ "cameras": "Kameros",
+ "labels": "Etiketės",
+ "zones": "Zonos",
+ "search_type": "Paieškos Tipas",
+ "time_range": "Laiko rėžis",
+ "before": "Prieš",
+ "after": "Po",
+ "min_score": "Min Balas",
+ "max_score": "Max Balas",
+ "min_speed": "Min Greitis",
+ "max_speed": "Max Greitis",
+ "recognized_license_plate": "Atpažinti Registracijos Numeriai",
+ "has_clip": "Turi Klipą",
+ "has_snapshot": "Turi Nuotrauką",
+ "sub_labels": "Sub Etiketės",
+ "attributes": "Atributai"
+ },
+ "searchType": {
+ "thumbnail": "Miniatiūra",
+ "description": "Aprašymas"
+ },
+ "toast": {
+ "error": {
+ "beforeDateBeLaterAfter": "Data 'prieš' turi būti vėliau nei data 'po'.",
+ "afterDatebeEarlierBefore": "Data 'po' turi būti anksčiau nei data 'prieš'.",
+ "minScoreMustBeLessOrEqualMaxScore": "'min balas' turi būti mažesnis arba lygus 'max balui'.",
+ "maxScoreMustBeGreaterOrEqualMinScore": "'max balas' turi būti didesnis arba lygus 'min balui'.",
+ "minSpeedMustBeLessOrEqualMaxSpeed": "'min greitis' privalo būti mažesnis arba lygus 'max greičiui'.",
+ "maxSpeedMustBeGreaterOrEqualMinSpeed": "'max greitis' privalo būti didesnis arba lygus 'min greičiui'."
+ }
+ },
+ "tips": {
+ "title": "Kaip naudoti tekstinius filtrus",
+ "desc": {
+ "text": "Filtrai leidžia susiaurinti paieškos rezultatus. Štai kaip juos naudoti įvesties laukelyje:",
+ "step1": "Įveskite filtravimo raktą po kurio seks dvitaškis (pvz., \"cameras:\").",
+ "step2": "Pasirinkite reikšmę iš siūlomų arba įveskite savo sugalvotą.",
+ "step3": "Naudokite kelis filtrus įvesdami juos vieną paskui kitą su tarpu tarp jų.",
+ "step5": "Laiko rėžio filtro naudojamas {{exampleTime}} formatas.",
+ "step6": "Pašalinti filtrus spaudžiant 'x' šalia jų.",
+ "exampleLabel": "Pavyzdys:",
+ "step4": "Datų filtrai (before: and after:) naudoti {{DateFormat}} formatą."
+ }
+ },
+ "header": {
+ "currentFilterType": "Filtruoti Reikšmes",
+ "noFilters": "Filtrai",
+ "activeFilters": "Aktyvūs Filtrai"
}
+ },
+ "similaritySearch": {
+ "title": "Panašumų Paieška",
+ "active": "Panašumų paieška aktyvi",
+ "clear": "Išvalyti panašumų paiešką"
+ },
+ "placeholder": {
+ "search": "Ieškoma…"
}
}
diff --git a/web/public/locales/lt/views/settings.json b/web/public/locales/lt/views/settings.json
index 15a9e53c7..360f78d49 100644
--- a/web/public/locales/lt/views/settings.json
+++ b/web/public/locales/lt/views/settings.json
@@ -3,10 +3,1003 @@
"default": "Nustatymai - Frigate",
"authentication": "Autentifikavimo Nustatymai - Frigate",
"camera": "Kameros Nustatymai - Frigate",
- "object": "Derinti - Frigate",
- "general": "Bendrieji Nustatymai - Frigate",
+ "object": "Debug - Frigate",
+ "general": "Vizualiniai Nustatymai - Frigate",
"frigatePlus": "Frigate+ Nustatymai - Frigate",
"notifications": "Pranešimų Nustatymai - Frigate",
- "motionTuner": "Judesio Derinimas - Frigate"
+ "motionTuner": "Judesio Derinimas - Frigate",
+ "enrichments": "Patobulinimų Nustatymai - Frigate",
+ "masksAndZones": "Maskavimo ir Zonų redaktorius - Frigate",
+ "cameraManagement": "Valdyti Kameras - Frigate",
+ "cameraReview": "Kameros Peržiūros Nustatymai - Frigate"
+ },
+ "menu": {
+ "ui": "UI",
+ "enrichments": "Patobulinimai",
+ "cameras": "Kameros Nustatymai",
+ "masksAndZones": "Maskavimai / Zonos",
+ "motionTuner": "Judesio Derintojas",
+ "debug": "Debug",
+ "users": "Vartotojai",
+ "notifications": "Pranešimai",
+ "frigateplus": "Frigate+",
+ "triggers": "Trigeriai",
+ "roles": "Rolės",
+ "cameraManagement": "Valdymas",
+ "cameraReview": "Peržiūra"
+ },
+ "dialog": {
+ "unsavedChanges": {
+ "title": "Yra neišsaugotų pakeitimų.",
+ "desc": "Ar norite išsaugoti savo pakeitimus prieš tęsdami?"
+ }
+ },
+ "cameraSetting": {
+ "camera": "Kamera",
+ "noCamera": "Nėra Kameros"
+ },
+ "general": {
+ "title": "Vartotojo Sąsajos Nustatymai",
+ "liveDashboard": {
+ "title": "Tiesioginės Transliacijos Skydelis",
+ "automaticLiveView": {
+ "label": "Automatinis Tiesioginis Vaizdas",
+ "desc": "Automatiškai perjungti į kameros tiesioginį vaizdą kai aptinkama veikla. Išjungus šią funkciją tiesioginės transliacijos skydelyje kamerų vaizdai atsinaujis tik kartą per minutę."
+ },
+ "playAlertVideos": {
+ "label": "Leist Įspejimų Vaizdus",
+ "desc": "Pagal nutylėjimą, paskutinieji įspėjimai rodomį kaip maži cikliški vaizdo įrašai. Šią funkciją išjunkite jei norite matyti statinius įspėjimų paveiksliukus šiame įrenginyje/naršyklėje."
+ },
+ "displayCameraNames": {
+ "label": "Visada Rodyti Kamerų Pavadinimus",
+ "desc": "Keletos kamerų tiesioginės transliacijos tinklelyje visada rodyti kameros pavadinimą žymoje."
+ },
+ "liveFallbackTimeout": {
+ "label": "Transliacijos atstatymas neišlauktas",
+ "desc": "Kai kameros aukštos raiškos transliacija nepasiekiama, persijungti į žemos raiškos rėžimą po tiek tai sekundžių. Default: 3."
+ }
+ },
+ "storedLayouts": {
+ "title": "Išsaugoti Išdėstymai",
+ "desc": "Kamerų išdėstymai kamerų grupėje gali būti perkeliami/keičiami dydžiai. Pozicijos išsaugomos jūsų naršyklės vietinėje atmintyje.",
+ "clearAll": "Išvalyti Visus Išdėstymus"
+ },
+ "cameraGroupStreaming": {
+ "title": "Kamerų Grupės Transliacijos Nustatymai",
+ "desc": "Transliacijos nustatymai kiekvienai kamerų grupei yra saugomi jūsų naršyklės vietinėje atmintyje.",
+ "clearAll": "Išvalyti Visus Transliavimo Nustatymus"
+ },
+ "recordingsViewer": {
+ "title": "Įrašų Naršyklė",
+ "defaultPlaybackRate": {
+ "label": "Numatytasis Atkūrimo Dažnis",
+ "desc": "Numatytas atkūrimo dažnis įrašų atkūrimui."
+ }
+ },
+ "calendar": {
+ "title": "Kalendorius",
+ "firstWeekday": {
+ "label": "Pirma Savaitės Diena",
+ "desc": "Diena kuria prasideda savaitės peržiūrų kalendoriuje.",
+ "sunday": "Sekmadienis",
+ "monday": "Pirmadienis"
+ }
+ },
+ "toast": {
+ "success": {
+ "clearStoredLayout": "Saugoti išdėstimai kamerai{{cameraName}} išvalyti",
+ "clearStreamingSettings": "Visų kamerų grupių transliavimo nustatymai išvalyti."
+ },
+ "error": {
+ "clearStoredLayoutFailed": "Nepavyko išvalyti išsaugotų pozicijų išdėstymų: {{errorMessage}}",
+ "clearStreamingSettingsFailed": "Nepavyko išvalyti transliavimo nustatymų: {{errorMessage}}"
+ }
+ }
+ },
+ "enrichments": {
+ "title": "Pagerinimų Nustatymai",
+ "unsavedChanges": "Neišsaugoti Pagerinimų nustatymų pakeitimai",
+ "birdClassification": {
+ "title": "Paukščių Klasifikatorius",
+ "desc": "Paukščių klasifikatorius identifikuoja žinomus paukščius naudojant kvantinizuotą Tensorflow modelį. Kai žinomas paukštis atpažįstamas, jo bendrinis pavadinimas bus pridėtas prie sub_etikečių. Ši informacija yra pridedama vartotojo sąsajoje, filtruose, taip pat ir pranešimuose."
+ },
+ "semanticSearch": {
+ "title": "Semantic Paieška",
+ "desc": "Frigate Semantic Paieška leidžia jums atrasti sekamus objektus tarp peržiūrų, naudojant arba pačius paveiksliuks, vartotojo pateiktus tekstinius aprašymus arba automatiškai sugeneruotas reikšmes.",
+ "reindexNow": {
+ "label": "Perindeksuoti Dabar",
+ "desc": "Perindeksavimas sugeneruos įterpinius visiems sekamiems objektams. Šis procesas veiks fone ir priklausomai nuo jūsų turimo sekamų objektų kiekio gali maksimaliai apkrauti jūsų CPU bei užtrukti nemažai laiko.",
+ "confirmTitle": "Patvirtinti Reindeksavimą",
+ "confirmDesc": "Ar esate įsitikinę, kad norite reindeksuoti visų sekamų objektų įterpius? Šis processas veiks fone ir gali maksimaliai apkrauti jūsų CPU bei užtrukti nemažai laiko. Progresą jūs galėsite stebėti Tyrinėjimo puslapyje.",
+ "confirmButton": "Reindeksuoti",
+ "success": "Reindeksavimas pradėtas sėkmingai.",
+ "alreadyInProgress": "Redindeksavimas jau vykdomas.",
+ "error": "Nepavyko pradėti reindeksavimo: {{errorMessage}}"
+ },
+ "modelSize": {
+ "label": "Modelio Dydis",
+ "desc": "Modelio dydis naudojamas semantic paieškos įterpiuose.",
+ "small": {
+ "title": "mažas",
+ "desc": "Naudojant mažą pasitelkiama kvantizuota modelio versija kuri reikalauja mažiau RAM, naudojant CPU veikia greičiau su nežįmiu skirtumu įterpių kokybei."
+ },
+ "large": {
+ "title": "didelis",
+ "desc": "Naudojant didelį pasitelkiamas pilnas Jina modelis ir automatiškai naudos GPU jei yra galimas."
+ }
+ }
+ },
+ "faceRecognition": {
+ "title": "Veidų Atpažinimas",
+ "desc": "Veidų atpažinimas leidžia priskirti vardus žmonėms ir kai jų veidai atpažįstami Frigate priskirs žmogaus vardą kaip sub etiketę. Ši informacija prieinama vartotojo sąsajoje, filtruose, taip ir pranešimuose.",
+ "modelSize": {
+ "label": "Modelio Dydis",
+ "desc": "Modelio dydis naudojamas veidų atpažinimui.",
+ "small": {
+ "title": "mažas",
+ "desc": "Naudojant mažą pasitelkiamas FaceNet veidų įterpių modelis kuris efektyviai veikia su daugeliu CPU."
+ },
+ "large": {
+ "title": "didelis",
+ "desc": "Naudojant didelį pasitelkiamas ArcFace face embedding modelis ir jei yra galimybė automatiškai naudos GPU."
+ }
+ }
+ },
+ "licensePlateRecognition": {
+ "title": "Registracijos Numerių Atpažinimas",
+ "desc": "Frigate gali atpažinti automobilių registracijos numerius ir automatiškai pridėti aptikitus simbolius į \"recognized_license_plate\" laukelį arba žinoma pavadinima kaip sub_etiketę \"mašina\" tipo objektams. Dažnas panaudojimas būtų nuskaityti numerius mašinų įvažiuojančių į įvažiavimą arba mašinų pravažiuojančių gatve."
+ },
+ "restart_required": "Privaloma perkrauti (Patobulinimų nustatymai pakeisti)",
+ "toast": {
+ "success": "Patobulinimų nustaty buvo pakeisti. Kad pkyčiai būtų pritaikyti perkraukite Frigate.",
+ "error": "Nepavyko išsaugoti konfiguracijos pakeitimų: {{errorMessage}}"
+ }
+ },
+ "camera": {
+ "title": "Kamerų Nustatymai",
+ "streams": {
+ "title": "Transliacijos",
+ "desc": "Laikinai išjunkite kamerą kol Frigate bus perkrautas. Išjungiant kamerą visiškai sustabdo Frigate veiklą šiai kamerai. Nebus aptikimų, įrašų ar debug informacijos.Judesio Dėžutės
Raudonos dėžutės bus kadro vietose kur judesys yra aptiktas
" + }, + "regions": { + "title": "Regionai", + "desc": "Rodyti dėžutes regionų kurie yra parduoti į detektorių", + "tips": "Regionų Dėžutės
Ryškiai žalios dėžutės atvaizduojamos vietose kurios yra perduotos objektų detektoriui.
" + }, + "paths": { + "title": "Keliai", + "desc": "Rodyti sekamo objekto kelio išskirtinius taškus", + "tips": "Keliai
Linijos ir apskritimai nurodo sekamo objekto judėjimo išskirtinius taškus
" + }, + "objectShapeFilterDrawing": { + "title": "Filtrų Brėžiniai Objektų Formoms", + "desc": "Norėdami sužinoti atvaizdo plotą ir santykio detales nubrėžkite keturkampį ant atvaizdo", + "score": "Balai", + "ratio": "Santykis", + "area": "Plotas", + "tips": "Įjunkite šią funkciją nupiešti keturkampį ant kameros vaizdo, kad parodyti plotą ir santykį. Šios reikšmės gali būti naudojamos objekto formos filtro parametrams jūsų konfiguracijoje." + } + }, + "users": { + "dialog": { + "deleteUser": { + "warn": "Ar esate įsitikinę, kad norite ištrinti {{username}}?", + "title": "Ištrinti Vartotoją", + "desc": "Šis veiksmas negalės būti atkurtas. Tai visam laikui ištrins vartotojo paskyrą ir ištrins visą susijusią informaciją." + }, + "form": { + "user": { + "title": "Vartotojo vardas", + "desc": "Leidžiamos tik raidės, skaičiai, taškai ir pabraukimai.", + "placeholder": "Įvesti vartotojo vardą" + }, + "password": { + "title": "Slaptažodis", + "placeholder": "Įvesti slaptažodį", + "confirm": { + "title": "Patvirtinti Slaptažodį", + "placeholder": "Patvirtinti Slaptažodį" + }, + "strength": { + "title": "Slaptažodžio sudėtingumas: ", + "weak": "Silpnas", + "medium": "Vidutinis", + "strong": "Stiprus", + "veryStrong": "Labai Stiprus" + }, + "match": "Slaptažodžiai sutampa", + "notMatch": "Slaptažodžiai nesutampa" + }, + "newPassword": { + "title": "Naujas Slaptažodis", + "placeholder": "Įveskite naują slaptažodį", + "confirm": { + "placeholder": "Pakartokite naują slaptažodį" + } + }, + "usernameIsRequired": "Vartotojo vardas yra privalomas", + "passwordIsRequired": "Slaptažodis yra privalomas" + }, + "createUser": { + "title": "Sukurti Naują Vartotoją", + "desc": "Pridėti naują vartotojo paskyrą ir nurodyti prieigos roles prie Frigate funkcijų.", + "usernameOnlyInclude": "Vartotojo vardas gali būti sudarytas iš raidžių, skaičių, . arba _", + "confirmPassword": "Prašome patvirtinti slaptažodį" + }, + "passwordSetting": { + "cannotBeEmpty": "Slaptažodis negali būti tuščias", + "doNotMatch": "Slaptažodžiai nesutampa", + "updatePassword": "Atnaujinkite Spaltažodį vartotojui {{username}}", + "setPassword": "Sukurti Slaptažodį", + "desc": "Sukurti stiprų slaptažodį kad apsaugoti paskyrą." + }, + "changeRole": { + "title": "Pakeisti vartotojo Rolę", + "select": "Pasirinkti rolę", + "desc": "Atnaujinti leidimus vartotojui {{username}}", + "roleInfo": { + "intro": "Pasirinkti tinkama rolę šiam vartotojui:", + "admin": "Admin", + "adminDesc": "Pilna prieiga prie visų funkcijų.", + "viewer": "Žiūrovas", + "viewerDesc": "Leidžiama prie Tiesioginio vaizdo tinklelio, Peržiūrų, Paieškų ir Eksportavimo funkcijų.", + "customDesc": "Specializuota rolė su prieiga prie konkrečios kameros." + } + } + }, + "title": "Vartotojai", + "management": { + "title": "Vartotojų Valdymas", + "desc": "Valdyti šios Frigate aplinkos vartotojų paskyras." + }, + "addUser": "Pridėti Vartotoją", + "updatePassword": "Atkurti Slaptažodį", + "toast": { + "success": { + "createUser": "Vartotojas {{user}} sėkmingai sukurtas", + "deleteUser": "Vartotojas {{user}} sėkmingai ištrintas", + "updatePassword": "Slaptažodis atnaujintas sėkmingai.", + "roleUpdated": "Vartotojui {{user}} rolė sėkmingai atnaujinta" + }, + "error": { + "setPasswordFailed": "nepavyko išsaugoti slaptažodžio: {{errorMessage}}", + "createUserFailed": "Nepavyko sukurti vartotojo: {{errorMessage}}", + "deleteUserFailed": "Nepavyko ištrinti vartotojo: {{errorMessage}}", + "roleUpdateFailed": "Nepavyko atnaujinti rolės: {{errorMessage}}" + } + }, + "table": { + "username": "Vartotojo vardas", + "actions": "Veiksmai", + "role": "Rolė", + "noUsers": "Vartotojų nerasta.", + "changeRole": "Pakeisti vartotojo rolę", + "password": "Atkurti Slaptažodį", + "deleteUser": "Ištrinti vartotoją" + } + }, + "triggers": { + "dialog": { + "deleteTrigger": { + "desc": "Ar esate įsitikinę, kad norite ištrinti trigerį {{triggerName}}? Šis veiksmas negalės būti atstatytas.", + "title": "Ištrinti Trigerį" + }, + "createTrigger": { + "title": "Sukurti Trigerį", + "desc": "Sukurti trigerį kamerai {{camera}}" + }, + "editTrigger": { + "title": "Koreguoti Trigerį", + "desc": "Koreguoti trigerio nustatymus kamerai {{camera}}" + }, + "form": { + "name": { + "title": "Pavadinimas", + "placeholder": "Užvadinkite trigerį", + "error": { + "minLength": "Laukelis turi būti bent dviejų simbolių ilgio.", + "invalidCharacters": "Laukelyje gali būti tik raidės, skaičiai, pabraukimai ir brūkšnelis.", + "alreadyExists": "Trigeris su tokiu vardu jau yra šiai kamerai." + } + }, + "enabled": { + "description": "Įjungti ar išjungti šį trigerį" + }, + "type": { + "title": "Tipas", + "placeholder": "Pasirinkti trigerio tipą" + }, + "content": { + "title": "Turinys", + "imagePlaceholder": "Parinkti miniatiūrą", + "textPlaceholder": "Įvesti teksto turinį", + "imageDesc": "Rodoma tik 100 paskutinių miniatiūrų. Jei norimos miniatiūros nerandate, galite ieškoti senesnių įrašų per Paieškų meniu ir tenai kurti trigerį.", + "textDesc": "Įveskite tekstą kad inicijuotumėte veiksmą kai panašus sekamo objekto aprašymas bus aptiktas.", + "error": { + "required": "Turinys privalomas." + } + }, + "threshold": { + "title": "Riba", + "error": { + "min": "Riba privalo būti bent jau 0", + "max": "Riba privalo būti daugiausiai 1" + } + }, + "actions": { + "title": "Veiksmai", + "desc": "Pagal nutylėjimą, Frigate sukuria MQTT žinutę visiem trigeriams. Subetiketės prideda trigerio pavadinimą prie objekto etiketės. Atributai, tai paieškai pasiekiami metaduomenys saugomi atskirai sekamų objektų metaduomenyse.", + "error": { + "min": "Bent vienas veiksmas privalo būti parinktas." + } + }, + "friendly_name": { + "title": "Draugiškas Pavadinimas", + "placeholder": "Pavadinikite ar apibūdinkite trigerį", + "description": "Draugiškas pavadinimas ar apibūdinimas šiam trigeriui nėra būtinas." + } + } + }, + "documentTitle": "Trigeriai", + "management": { + "title": "Trigeriai", + "desc": "Valdykite trigerius kamerai {{camera}}. Naudokite miniatiūros tipą, kad panašios miniatiūros būtų jūsų pasirinkto objekto trigeris, o aprašymo trigerį kad panašūs aprašymai būtų trigeris pagal jūsų parašytą tekstą." + }, + "addTrigger": "Pridėti Trigerį", + "table": { + "name": "Pavadinimas", + "type": "Tipas", + "content": "Turinys", + "threshold": "Riba", + "actions": "Veiksmai", + "noTriggers": "Šiai kamerai nėra sukonfiguruotų trigerių.", + "edit": "Koreguoti", + "deleteTrigger": "Trinti Trigerį", + "lastTriggered": "Paskutinį kartą suveikė" + }, + "type": { + "thumbnail": "Miniatiūra", + "description": "Aprašymas" + }, + "actions": { + "alert": "Pažymėti kaip įspėjimą", + "notification": "Siųsti Pranešimą" + }, + "toast": { + "success": { + "createTrigger": "Trigeris {{name}} sėkmingai sukurtas.", + "updateTrigger": "Trigeris {{name}} sėkmingai atnaujintas.", + "deleteTrigger": "Trigeris {{name}} sėkmingai ištrintas." + }, + "error": { + "createTriggerFailed": "Nepavyko sukurti trigerio: {{errorMessage}}", + "updateTriggerFailed": "Nepavyko atnaujinti trigerio: {{errorMessage}}", + "deleteTriggerFailed": "Nepavyko ištrinti trigerio: {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "Semantic Paieška išjungta", + "desc": "Norint naudoti Trigerius Semantic Paieška privalo būti įjungta." + } + }, + "notification": { + "title": "Pranešimai", + "notificationSettings": { + "title": "Pranešimų Nustatymai", + "desc": "Frigate praneįimai sukurti veikti su push pranešimais į įrenginį kai naršoma per naršyklę arba įdiegta kaip PWA." + }, + "notificationUnavailable": { + "title": "Pranešimai Negalimi", + "desc": "Web push pranešimai reikalauja saugios aplinkos (https://...). Tai yra naršyklės apribojimai. Atsidarykit Frigate saugiu kanalu kad galėtumėte naudotis pranešimais."
+ },
+ "globalSettings": {
+ "title": "Visuotiniai Nustatymai",
+ "desc": "Laikinai sustabdyti pranešimus iš konkrečios kameros į registruotus įrenginius."
+ },
+ "email": {
+ "title": "El.paštas",
+ "placeholder": "pvz.: laiskas@laiskas.com",
+ "desc": "El paštas turi būti veikiantis ir jums prieinamas, kad jus pasiektų informacija jei bus problemų su push pranešimų paslauga."
+ },
+ "cameras": {
+ "title": "Kameros",
+ "noCameras": "Nėra kamerų",
+ "desc": "Pasirinkite kurioms kameroms norite įjungti pranešimus."
+ },
+ "deviceSpecific": "Įrenginio Specifiniai Nustatymai",
+ "registerDevice": "Registruoti Šį Įrenginį",
+ "unregisterDevice": "Išregistruoti Šį Įrenginį",
+ "sendTestNotification": "Siųsti bandomąjį pranešimą",
+ "unsavedRegistrations": "Neišsaugotos Pranešimo registracijos",
+ "unsavedChanges": "Neišsaugoti Pranešimų pakeitimai",
+ "active": "Aktyvūs Pranešimai",
+ "suspended": "Pranešimai sustabdyti {{time}}",
+ "suspendTime": {
+ "suspend": "Sustabdyti",
+ "5minutes": "Sustabdyti 5 minutėms",
+ "10minutes": "Sustabdyti 10 minučių",
+ "30minutes": "Sustabdyti 30 minučių",
+ "1hour": "Sustabdyti 1 valandai",
+ "12hours": "Sustabdyti 12 valandų",
+ "24hours": "Sustabdyti 24 valandoms",
+ "untilRestart": "Sustabdyti iki perkrovimo"
+ },
+ "cancelSuspension": "Atšaukti Sustabdymą",
+ "toast": {
+ "success": {
+ "registered": "Sėkmingai užregistruota pranešimams. Frigate perkrovimas yra būtinas, kad nors kokie pranešimai būtų išsiųsti (net ir bandomieji).",
+ "settingSaved": "Pranešimų nustatymai buvo išsaugoti."
+ },
+ "error": {
+ "registerFailed": "Nepavyko išsaugoti pranešimų registravimo."
+ }
+ }
+ },
+ "frigatePlus": {
+ "title": "Frigate+ Nustatymai",
+ "apiKey": {
+ "title": "Frigate+ API raktas",
+ "validated": "Frigate+ API raktas aptiktas ir patvirtintas",
+ "notValidated": "Frigate+ API raktas neaptiktas ir nepatvirtintas",
+ "desc": "Frigate+ API raktas įgalina integraciją su Frigate+ paslauga.",
+ "plusLink": "Skaityti daugiau apie Frigate+"
+ },
+ "snapshotConfig": {
+ "title": "Momentinių kadrų Konfiguravimas",
+ "desc": "Pateikti į Frigate+ reikalauja abiejų, momentinių kadrų ir švarios_kopijosmomentinių kadrų įjungimo jūsų konfiguracijoje.",
+ "cleanCopyWarning": "Kai kurios kameros turi momentinius kadrus įjungtus tačiau švari kopija išjungta. Turite įjungti švarią_kopiją savo momentinės kopijos nustatymuose, kad galėtumėte teikti paveikslėlius į Frigate+.",
+ "table": {
+ "camera": "Kamera",
+ "snapshots": "Momentiniai Kadrai",
+ "cleanCopySnapshots": "Momentiniai kadrai švari_kopija"
+ }
+ },
+ "modelInfo": {
+ "title": "Modelio Informacija",
+ "modelType": "Modelio Tipas",
+ "trainDate": "Apmokymo Data",
+ "baseModel": "Bazinis Modelis",
+ "plusModelType": {
+ "baseModel": "Bazinis Modelis",
+ "userModel": "Priderinta"
+ },
+ "supportedDetectors": "Palaikomi Detektoriai",
+ "cameras": "Kameros",
+ "loading": "Užkraunama modelio informacija…",
+ "error": "Nepavyko užkrauti modelio informacijos",
+ "availableModels": "Pireinami Modeliai",
+ "loadingAvailableModels": "Kraunami prieinami modeliai…",
+ "modelSelect": "Jūsų prieinami modeliai iš Frigate+ gali būti pasirinkti čia. Pastaba, pasirinkiti galite modelius tik tuos kurie suderinami su esamu detektoriumi."
+ },
+ "unsavedChanges": "Neišsaugoti Frigate+ nustatymų pokyčiai",
+ "restart_required": "Perkrovimas privalomas (Frigate+ modeliai pakeisti)",
+ "toast": {
+ "success": "Frigate+ nustatymai buvo išsaugoti. Perkraukite Frigate kad pritaikytumėte pokyčius.",
+ "error": "Nepavyko išsaugoti konfiguraijos pokyčių: {{errorMessage}}"
+ }
+ },
+ "roles": {
+ "addRole": "Pridėti rolę",
+ "table": {
+ "role": "Rolė",
+ "cameras": "Kameros",
+ "actions": "Veiksmai",
+ "deleteRole": "Pašalinti rolę",
+ "noRoles": "Specializuotų rolių nerasta.",
+ "editCameras": "Koreguoti Kameras"
+ },
+ "toast": {
+ "success": {
+ "deleteRole": "Rolė {{role}} sėkmingai pašalinta",
+ "userRolesUpdated_one": "{{count}} šios rolės vartotojas buvo priskirti rolei 'žiūrovas', kuri turi prieigą prie visų kamerų.",
+ "userRolesUpdated_few": "{{count}} šios rolės vartotojai buvo priskirti rolei 'žiūrovas', kuri turi prieigą prie visų kamerų.",
+ "userRolesUpdated_other": "{{count}} šios rolės vartotojų buvo priskirti rolei 'žiūrovas', kuri turi prieigą prie visų kamerų.",
+ "createRole": "Rolė {{role}} sėkmingai sukurta",
+ "updateCameras": "Atnaujintos kameros rolei {{role}}"
+ },
+ "error": {
+ "createRoleFailed": "Nepavyko sukurti rolės: {{errorMessage}}",
+ "updateCamerasFailed": "Nepavyko atnaujinti kamerų: {{errorMessage}}",
+ "deleteRoleFailed": "Nepavyko ištrinti rolės: {{errorMessage}}",
+ "userUpdateFailed": "Nepavyko atnaujinti vartotojo rolių: {{errorMessage}}"
+ }
+ },
+ "dialog": {
+ "deleteRole": {
+ "title": "Pašalinti rolę",
+ "deleting": "Šalinama...",
+ "desc": "Šis veiksmas neatkuriamas. Rolė bus ištrinta, likusiems jos turėtojams bus priskirta 'žiūrovo' rolė, kuri leis vartotojui matyti visas kameras.",
+ "warn": "Ar esate įsitikinę, kad norite ištrinti {{role}}?"
+ },
+ "form": {
+ "cameras": {
+ "title": "Kameros",
+ "required": "Mažiausiai viena kamera turi būti pažymėta.",
+ "desc": "Pasirinkinte kamerą prie kurios ši rolė suteiks prieigą. Privaloma nurodyti bent vieną."
+ },
+ "role": {
+ "title": "Rolės pavadinimas",
+ "placeholder": "Įveskite rolės pavadinimą",
+ "roleIsRequired": "Rolės pavadinimas yra privalomas",
+ "roleExists": "Toks rolės pavadinimas jau egzistuoja.",
+ "desc": "Ledžiama naudoti tik raides, skaičius, taškus ir pabraukimus.",
+ "roleOnlyInclude": "Rolės pavadinime gali būti tik raides, skaičius, . ar _"
+ }
+ },
+ "createRole": {
+ "title": "Sukurti Naują Rolę",
+ "desc": "Pridėti naują rolę ir priskirti prieigas prie kamerų."
+ },
+ "editCameras": {
+ "title": "Koreguoti Rolės Kameras",
+ "desc": "Atnaujinti prieigą prie kameros rolei {{role}}."
+ }
+ },
+ "management": {
+ "title": "Žiūrovo Rolės Valdymas",
+ "desc": "Valdyti šios Frigate aplinkos specializuotas žiūrovo roles ir kamerų prieigos leidimus."
+ }
+ },
+ "cameraWizard": {
+ "title": "Pridėti Kamerą",
+ "description": "Sekite žemiau nurodytus žingsnius norėdami pridėti naują kamerą prie savo Frigate.",
+ "steps": {
+ "nameAndConnection": "Pavadinimas ir Jungtis",
+ "streamConfiguration": "Transliacijos Nustatymai",
+ "validationAndTesting": "Patikra ir Testavimas",
+ "probeOrSnapshot": "Mėginys ar Kadras"
+ },
+ "save": {
+ "success": "Nauja kamera sėkmingai išsaugota {{cameraName}}.",
+ "failure": "Klaida išsaugant {{cameraName}}."
+ },
+ "testResultLabels": {
+ "resolution": "Rezoliucija",
+ "video": "Vaizdas",
+ "audio": "Garsas",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Prašau pateikti galiojantį transliacijos URL",
+ "testFailed": "Transliacijos testas nepavyko: {{error}}"
+ },
+ "step1": {
+ "description": "Įveskite savo kameros informaciją ir pasirinkite \"probe\" kamerai arba rankiniu būdų pasirinkite gamintoją.",
+ "cameraName": "Kameros Pavadinimas",
+ "cameraNamePlaceholder": "pvz., priekines_durys arba Galinio Kiemo Vaizdas",
+ "host": "Host/IP Adresas",
+ "port": "Port",
+ "username": "Vartotojo vardas",
+ "usernamePlaceholder": "Pasirinktinai",
+ "password": "Slaptažodis",
+ "passwordPlaceholder": "Pasirinktinai",
+ "selectTransport": "Pasirinkite perdavimo protokolą",
+ "cameraBrand": "Kameros Gamintojas",
+ "selectBrand": "Pasirinkite kameros gamintoją URL šablonui",
+ "customUrl": "Kameros Transliacijos URL",
+ "brandInformation": "Gamintojo informacija",
+ "brandUrlFormat": "Kamerai su RTSP URL formatas kaip: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://vartotojas:slaptažodis@host:port/path",
+ "testConnection": "Testuoti Susijungimą",
+ "testSuccess": "Susijungimo testas sėkmingas!",
+ "connectionSettings": "Prisijungimo Nustatymai",
+ "detectionMethod": "Transliacijos Aptikimo Metodas",
+ "onvifPort": "ONVIF Portas",
+ "probeMode": "Probuoti kamerą",
+ "manualMode": "Rankinis pasirinkimas",
+ "detectionMethodDescription": "Probuoti kamerą su ONVIF (jei palaikomas), kad rasti kameros srautų URL, arba rankiniu būdu pasirinkite kameros gamintoją kad naudoti iš anksto žinomus URL adresus. Kad įvesti individualų RTSP URL, pasirinkite rankinį metodą ir pasirinkite \"Kitas\".",
+ "onvifPortDescription": "Kameroms su palaikomu ONVIF, tai dažniausiai 80 ar 8080.",
+ "useDigestAuth": "Naudoti digest autentifikavimą",
+ "useDigestAuthDescription": "Naudoti HTTP digest autentifikavimą su ONVIF. Kai kurios kameros gali reikalauti priskirto ONVIF vartojo/ slaptažodžio vietoje standartinio admin vartotojo.",
+ "errors": {
+ "brandOrCustomUrlRequired": "Arba pasirinkite kameros gamintoją su host/IP arb rinkites 'Kita' su individualiu URL",
+ "nameRequired": "Kameros pavadinimas privalomas",
+ "nameLength": "Kameros pavadinimas privalo būti 64 ar mažiau simbolių",
+ "invalidCharacters": "Kameros pavadinime yra neleistinų simbolių",
+ "nameExists": "Toks kameros pavadinimas jau yra",
+ "customUrlRtspRequired": "Individualus URL turi prasidėti su \"rtsp://\". Rankinis konfiguravimas yra reikalaujas ne-RTSP kamerų transliacijoms."
+ }
+ },
+ "step2": {
+ "description": "Probuoti kamerą srautams atrasti ar konfiguruoti nustatymus rankiniu būdų pasirinktam aptikimo metodui.",
+ "testSuccess": "Prisijungimo testas sėkmingas!",
+ "testFailed": "Prisijungimo testas nepavyko. Prašau patikrinkite savo įvestis ir bandykite vėl.",
+ "testFailedTitle": "Testas Nepavyko",
+ "streamDetails": "Srauto Detalės",
+ "probing": "Probuojama kamera...",
+ "retry": "Pakartoti",
+ "testing": {
+ "probingMetadata": "Probuojami kameros metaduomenys...",
+ "fetchingSnapshot": "Gaunama kameros atvaizdas..."
+ },
+ "probeFailed": "Nepavyko probuoti kameros: {{error}}",
+ "probingDevice": "Probuojamas įrenginys...",
+ "probeSuccessful": "Probuojamas sėkmingas",
+ "probeError": "Probavimo Klaida",
+ "probeNoSuccess": "Probavimas nesėkmingas",
+ "deviceInfo": "Įrenginio Informacija",
+ "manufacturer": "Gamintojas",
+ "model": "Modelis",
+ "firmware": "Programinė Įranga",
+ "profiles": "Profiliai",
+ "ptzSupport": "PTZ Palaikymas",
+ "autotrackingSupport": "Autosekimo Palaikymas",
+ "presets": "Paruoštukai",
+ "rtspCandidates": "RTSP Kandidatai",
+ "rtspCandidatesDescription": "Sekantys RTSP URL adresai buvo rasti probuojant kamerą. Testuoti prisijungimą kad pamatyti srauto metaduomenis.",
+ "noRtspCandidates": "Iš kameros nerasta RTSP URL'ų. Jūsų prisijungimo duomenys gali būti neteisingi. ar kamera nepalaiko ONVIF ar metodas naudotas rasti RTSP URL. Grįžkite atgal ir rankiniu būdu suveskite RTSP URL.",
+ "candidateStreamTitle": "Kandidatų {{number}}",
+ "useCandidate": "Naudoti",
+ "uriCopy": "Kopijuoti",
+ "uriCopied": "URI nukopijuotas į iškarpinę",
+ "testConnection": "Testuoti Prisijungimą",
+ "toggleUriView": "Spustelkit kad atskleisti pilną URI vaizdą",
+ "connected": "Prisijungta",
+ "notConnected": "Neprisijungta",
+ "errors": {
+ "hostRequired": "Host/IP adresas yra privalomas"
+ }
+ },
+ "step3": {
+ "description": "Konfiguruoti srauto roles ir prideti papildomus srautus jūsų kamerai.",
+ "streamsTitle": "Kameros Srautai",
+ "addStream": "Pridėti Srautus",
+ "addAnotherStream": "Dar Pridėti Srautą",
+ "streamTitle": "Srautų {{number}}",
+ "streamUrl": "Srauto URL",
+ "streamUrlPlaceholder": "rtsp://vartotojas:slaptažodis@host:port/kelias",
+ "selectStream": "Pasirinkti srautą",
+ "searchCandidates": "Ieškoti kandidatų...",
+ "noStreamFound": "Srautų nerasta",
+ "url": "URL",
+ "resolution": "Raiška",
+ "selectResolution": "Pasirinkti raišką",
+ "quality": "Kokybė",
+ "selectQuality": "Pasirinkti kokybę",
+ "roles": "Rolės",
+ "roleLabels": {
+ "detect": "Objektų Aptikimas",
+ "record": "Įrašymas",
+ "audio": "Garsas"
+ },
+ "testStream": "Testuoti Prisijungimą",
+ "testSuccess": "Srauto testas sėkmingas!",
+ "testFailed": "Srauto testas nepavyko",
+ "testFailedTitle": "Testas Nepavyko",
+ "connected": "Prisijungta",
+ "notConnected": "Neprisijungta",
+ "featuresTitle": "Savybės",
+ "go2rtc": "Sumažinti prisijungimų prie kameros",
+ "detectRoleWarning": "Bent vienas srautas privalo turėti \"aptikimo\" rolę norint tęsti.",
+ "rolesPopover": {
+ "title": "Srauto Rolės",
+ "detect": "Pagrindinis srautas ojektų aptikimui.",
+ "record": "Įrašo vaizdo segmentus pagal konfiguracijos nustatymus.",
+ "audio": "Srautas audio aptikimams."
+ },
+ "featuresPopover": {
+ "title": "Srauto Savybės",
+ "description": "Naudoti go2rtc pertransliavimą kad sumažinti prisijungimus prie kameros."
+ }
+ },
+ "step4": {
+ "description": "Galutinis patvirtinimas ir analizė prieš išsaugant jūsų naują kamerą. Prijunkite kiekvieną srautą prieš išsaugant.",
+ "validationTitle": "Srauto Tikrinimas",
+ "connectAllStreams": "Prijungti Visus Srautus",
+ "reconnectionSuccess": "Pakartotinis Prisijungimas Sėkmingas.",
+ "reconnectionPartial": "Prie kai kurių srautų nepavyko atstatyti prisijungimo.",
+ "streamUnavailable": "Srauto peržiūra negalia",
+ "reload": "Perleisti",
+ "connecting": "Prisijungiama...",
+ "streamTitle": "Srautų {{number}}",
+ "valid": "Tinkamas",
+ "failed": "Nepavyko",
+ "notTested": "Netestuota",
+ "connectStream": "Prijungti",
+ "connectingStream": "Prisijungiama",
+ "disconnectStream": "Atsijungti",
+ "estimatedBandwidth": "Tikėtinas Greitis",
+ "roles": "Rolės",
+ "ffmpegModule": "Naudoti srauto pritaikymo rėžimą"
+ }
}
}
diff --git a/web/public/locales/lt/views/system.json b/web/public/locales/lt/views/system.json
index fb9784cf7..06493b4f6 100644
--- a/web/public/locales/lt/views/system.json
+++ b/web/public/locales/lt/views/system.json
@@ -7,13 +7,202 @@
"go2rtc": "Go2RTC Žurnalas - Frigate",
"nginx": "Nginx Žurnalas - Frigate"
},
- "general": "Bendroji Statistika - Frigate"
+ "general": "Bendroji Statistika - Frigate",
+ "enrichments": "Pagerinimų Statistika - Frigate"
},
"title": "Sistema",
"metrics": "Sistemos metrikos",
"logs": {
"download": {
"label": "Parsisiųsti Žurnalą"
+ },
+ "copy": {
+ "label": "Kopijuoti į iškarpinę",
+ "success": "Nukopijuoti įrašai į iškarpinę",
+ "error": "Nepavyko nukopijuoti įrašų į iškarpinę"
+ },
+ "type": {
+ "label": "Tipas",
+ "timestamp": "Laiko žymė",
+ "tag": "Žyma",
+ "message": "Žinutė"
+ },
+ "tips": "Įrašai yra transliuojami iš serverio",
+ "toast": {
+ "error": {
+ "fetchingLogsFailed": "Klaida nuskaitant įrašus: {{errorMessage}}",
+ "whileStreamingLogs": "Klaidai transliuojant įrašus: {{errorMessage}}"
+ }
}
+ },
+ "general": {
+ "title": "Bendrinis",
+ "detector": {
+ "title": "Detektoriai",
+ "inferenceSpeed": "Detektorių darbo greitis",
+ "temperature": "Detektorių Temperatūra",
+ "cpuUsage": "Detektorių CPU Naudojimas",
+ "memoryUsage": "Detektorių Atminties Naudojimas",
+ "cpuUsageInformation": "CPU vartojimas ruošiant duomenis detektorių modeliams. Ši reikšmė nevertina inference vartojimo, net jei yra naudojamas GPU akseleratorius."
+ },
+ "hardwareInfo": {
+ "title": "Techninės įrangos Info",
+ "gpuUsage": "GPU Naudojimas",
+ "gpuMemory": "GPU Atmintis",
+ "gpuEncoder": "GPU Kodavimas",
+ "gpuDecoder": "GPU Dekodavimas",
+ "gpuInfo": {
+ "vainfoOutput": {
+ "title": "Vainfo Išvestis",
+ "returnCode": "Grįžtamas Kodas: {{code}}",
+ "processOutput": "Proceso Išvestis:",
+ "processError": "Proceso Klaida:"
+ },
+ "nvidiaSMIOutput": {
+ "title": "Nvidia SMI Išvestis",
+ "name": "Pavadinimas: {{name}}",
+ "driver": "Tvarkyklė: {{driver}}",
+ "cudaComputerCapability": "CUDA Compute Galimybės: {{cuda_compute}}",
+ "vbios": "VBios Info: {{vbios}}"
+ },
+ "closeInfo": {
+ "label": "Užverti GPU info"
+ },
+ "copyInfo": {
+ "label": "Kopijuoti GPU Info"
+ },
+ "toast": {
+ "success": "Nukopijuota GPU info į iškarpinę"
+ }
+ },
+ "npuUsage": "NPU Naudojimas",
+ "npuMemory": "NPU Atmintis",
+ "intelGpuWarning": {
+ "title": "Intel GPU statistikų įspėjimas",
+ "message": "GPU statistika negalima",
+ "description": "Tai žinoma problema su Intel GPU statistikos raportavimo įrankiu (intel_gpu_top), kai jis stringa ir pakartotinai grąžina GPU vartojimas 0% net tais atvejais kai hardware acceleration ir objektų aptikimas taisiklingai veikia naudojant (i)GPU. Tai nėra Frigate klaida. Laikinai padeda įrenginio perkrovimas, kad įsitikinti teisingu GPU funkcionavimu. Tai neįtakoja spartos."
+ }
+ },
+ "otherProcesses": {
+ "title": "Kiti Procesai",
+ "processCpuUsage": "Procesų CPU Naudojimas",
+ "processMemoryUsage": "Procesu Atminties Naudojimas",
+ "series": {
+ "go2rtc": "go2rtc",
+ "recording": "įrašas",
+ "review_segment": "peržiūros segmentas",
+ "embeddings": "įterpiniai",
+ "audio_detector": "garso aptikiklis"
+ }
+ }
+ },
+ "storage": {
+ "title": "Saugykla",
+ "overview": "Apžvalga",
+ "recordings": {
+ "title": "Įrašai",
+ "tips": "Ši reikšmė nurodo kiek iš viso Frigate duombazėje esantys įrašai užima vietos saugykloje. Frigate neseka kiek vietos užima visi kiti failai esantys laikmenoje.",
+ "earliestRecording": "Anksčiausias esantis įrašas:"
+ },
+ "cameraStorage": {
+ "title": "Kameros Saugykla",
+ "camera": "Kamera",
+ "unusedStorageInformation": "Neišnaudotos Saugyklos Informacija",
+ "storageUsed": "Saugykla",
+ "percentageOfTotalUsed": "Procentas nuo Viso",
+ "bandwidth": "Pralaidumas",
+ "unused": {
+ "title": "Nepanaudota",
+ "tips": "Jei saugykloje turite daugiau failų apart Frigate įrašų, ši reikšmė neatspindės tikslios likusios laisvos vietos Frigate panaudojimui. Frigate neseka saugyklos panaudojimo už savo įrašų ribų."
+ }
+ },
+ "shm": {
+ "title": "SHM (bendrinama atmintis) priskyrimas",
+ "warning": "Esamas SHM dydis {{total}}MB yra per mažas. Pridėkite bent jau {{min_shm}}MB."
+ }
+ },
+ "cameras": {
+ "title": "Kameros",
+ "overview": "Apžvalga",
+ "info": {
+ "aspectRatio": "formato santykis",
+ "cameraProbeInfo": "{{camera}} Kameros srauto informacija",
+ "streamDataFromFFPROBE": "Transliacijos duomenys yra surenkami su ffprobe.",
+ "fetching": "Gaunamai Kameros Duomenys",
+ "stream": "Transliacija {{idx}}",
+ "video": "Vaizdas:",
+ "codec": "Kodekas:",
+ "resolution": "Raiška:",
+ "fps": "FPS:",
+ "unknown": "Nežinoma",
+ "audio": "Garsas:",
+ "error": "Klaida:{{error}}",
+ "tips": {
+ "title": "Kameros Srauto Informacija"
+ }
+ },
+ "framesAndDetections": "Kadrai / Aptikimai",
+ "label": {
+ "camera": "kamera",
+ "detect": "aptikti",
+ "skipped": "praleista",
+ "ffmpeg": "FFmpeg",
+ "capture": "užfiksuota",
+ "overallFramesPerSecond": "viso kadrų per sekundę",
+ "overallDetectionsPerSecond": "viso aptikimų per sekundę",
+ "overallSkippedDetectionsPerSecond": "viso praleista aptikimų per sekundę",
+ "cameraFfmpeg": "{{camName}} FFmpeg",
+ "cameraCapture": "{{camName}} ufiksuota",
+ "cameraDetect": "{{camName}} susekta",
+ "cameraFramesPerSecond": "{{camName}} kadrai per sekundę",
+ "cameraDetectionsPerSecond": "{{camName}} aptikimai per sekundę",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} praleista aptikimų per sekundę"
+ },
+ "toast": {
+ "success": {
+ "copyToClipboard": "Srauto informacija nukopijuotą į iškarpinę."
+ },
+ "error": {
+ "unableToProbeCamera": "Negalima gauti kameros mėginio: {{errorMessage}}"
+ }
+ }
+ },
+ "lastRefreshed": "Paskutinį kartą atnaujinta: ",
+ "stats": {
+ "ffmpegHighCpuUsage": "{{camera}} turi aukštą CPU suvartojimą FFmpeg ({{ffmpegAvg}}%)",
+ "detectHighCpuUsage": "{{camera}} turi auktšą CPU vartojimą aptikimams ({{detectAvg}}%)",
+ "healthy": "Sistemos būklė sveika",
+ "reindexingEmbeddings": "Įterpinių reideksavimas ({{processed}}% baigtas)",
+ "cameraIsOffline": "{{camera}} yra nepasiekiama",
+ "detectIsSlow": "{{detect}} yra lėtas ({{speed}}ms)",
+ "detectIsVerySlow": "{{detect}} yra labai lėtas ({{speed}}ms)",
+ "shmTooLow": "/dev/shm priskirta ({{total}} MB) turi būti padidinta bent jau iki {{min}} MB."
+ },
+ "enrichments": {
+ "title": "Patobulinimai",
+ "embeddings": {
+ "yolov9_plate_detection": "YOLOv9 Numerių Aptikimai",
+ "yolov9_plate_detection_speed": "YOLOv9 Numerių Aptikimų Greitis",
+ "text_embedding_speed": "Teksto Įterpimų Greitis",
+ "plate_recognition_speed": "Numerių Atpažinimo Greitis",
+ "face_recognition_speed": "Veidų Atpažinimo Greitis",
+ "face_embedding_speed": "Veidų Įterpimų Greitis",
+ "image_embedding_speed": "Vaizdo Įterpimo Greitis",
+ "plate_recognition": "Numerių Atpažinimas",
+ "face_recognition": "Veido Atpažinimas",
+ "text_embedding": "Teksto Įterpimas",
+ "image_embedding": "Vaizdo Įterpimas",
+ "review_description": "Apžvalgos Aprašymas",
+ "review_description_speed": "Apžvalgos Aprašymo Greitis",
+ "review_description_events_per_second": "Apžvalgos Aprašymas",
+ "object_description": "Objekto Aprašymas",
+ "object_description_speed": "Objekto Aprašymo Greitis",
+ "object_description_events_per_second": "Objekto Aprašymas",
+ "classification": "{{name}} Klasifikavimas",
+ "classification_speed": "{{name}} Klasifikavimo Greitis",
+ "classification_events_per_second": "{{name}} Klasifikavimo Įvykiai Per Sekundę"
+ },
+ "infPerSecond": "Išvadų Per Sekundę",
+ "averageInf": "Vidutinis Vertinimo Laikas"
}
}
diff --git a/web/public/locales/lv/audio.json b/web/public/locales/lv/audio.json
new file mode 100644
index 000000000..aab12a1b2
--- /dev/null
+++ b/web/public/locales/lv/audio.json
@@ -0,0 +1,35 @@
+{
+ "speech": "Runāšana",
+ "bicycle": "Velosipēds",
+ "babbling": "Pļāpāšana",
+ "car": "Automašīna",
+ "yell": "Kliedziens",
+ "motorcycle": "Motocikls",
+ "bellow": "Rēciens",
+ "whoop": "Izsauciens",
+ "bus": "Autobuss",
+ "whispering": "Čuksti",
+ "train": "Vilciens",
+ "insect": "Kukainis",
+ "mosquito": "Ods",
+ "fly": "Muša",
+ "frog": "Varde",
+ "snake": "Čūska",
+ "music": "Mūzika",
+ "musical_instrument": "Mūzikas instruments",
+ "plucked_string_instrument": "Stīgu instruments",
+ "guitar": "Ģitāra",
+ "electric_guitar": "Elektriskā ģitāra",
+ "bass_guitar": "Basģitāra",
+ "acoustic_guitar": "Akustiskā ģitāra",
+ "banjo": "Bandžo",
+ "piano": "Klavieres",
+ "electric_piano": "Sintezators",
+ "organ": "Ērģeles",
+ "electronic_organ": "Elektriskās ērģeles",
+ "harpsichord": "Klavesīns",
+ "laughter": "Smiekli",
+ "boat": "Laiva",
+ "snicker": "Ķiķināšana",
+ "camera": "Kamera"
+}
diff --git a/web/public/locales/lv/common.json b/web/public/locales/lv/common.json
new file mode 100644
index 000000000..3e8d06126
--- /dev/null
+++ b/web/public/locales/lv/common.json
@@ -0,0 +1,304 @@
+{
+ "time": {
+ "untilForTime": "Līdz {{time}}",
+ "today": "Šodien",
+ "yesterday": "Vakar",
+ "last7": "Pēdējās 7 dienas",
+ "last14": "Pēdējās 14 dienas",
+ "last30": "Pēdējās 30 dienas",
+ "thisWeek": "Šonedēļ",
+ "lastWeek": "Pagājušajā nedēļā",
+ "thisMonth": "Šomēnes",
+ "lastMonth": "Pagājušajā mēnesī",
+ "5minutes": "5 minūtes",
+ "10minutes": "10 minūtes",
+ "30minutes": "30 minūtes",
+ "1hour": "1 stunda",
+ "12hours": "12 stundas",
+ "24hours": "24 stundas",
+ "pm": "pm",
+ "am": "am",
+ "yr": "{{time}}g",
+ "year_zero": "{{time}} gadi",
+ "year_one": "{{time}} gads",
+ "year_other": "{{time}} gadi",
+ "mo": "{{time}}mēn",
+ "month_zero": "{{time}}mēneši",
+ "month_one": "{{time}}mēnesis",
+ "month_other": "{{time}}mēneši",
+ "d": "{{time}}d",
+ "day_zero": "{{time}} dienas",
+ "day_one": "{{time}} diena",
+ "day_other": "{{time}} dienas",
+ "h": "{{time}}s",
+ "hour_zero": "{{time}}stundas",
+ "hour_one": "{{time}}stunda",
+ "hour_other": "{{time}}stundas",
+ "m": "{{time}}m",
+ "minute_zero": "{{time}} minutes",
+ "minute_one": "{{time}} minute",
+ "minute_other": "{{time}} minutes",
+ "s": "{{time}}sek",
+ "second_zero": "{{time}} sekundes",
+ "second_one": "{{time}} sekunde",
+ "second_other": "{{time}} sekundes",
+ "formattedTimestamp": {
+ "12hour": "MMM d, h:mm:ss aaa",
+ "24hour": "MMM d, HH:mm:ss"
+ },
+ "formattedTimestamp2": {
+ "12hour": "MM/dd h:mm:ssa",
+ "24hour": "d MMM HH:mm:ss"
+ },
+ "formattedTimestampHourMinute": {
+ "12hour": "h:mm aaa",
+ "24hour": "HH:mm"
+ },
+ "formattedTimestampHourMinuteSecond": {
+ "12hour": "h:mm:ss aaa",
+ "24hour": "HH:mm:ss"
+ },
+ "formattedTimestampMonthDayHourMinute": {
+ "12hour": "MMM d, h:mm aaa",
+ "24hour": "MMM d, HH:mm"
+ },
+ "formattedTimestampMonthDayYear": {
+ "12hour": "MMM d, yyyy",
+ "24hour": "MMM d, yyyy"
+ },
+ "formattedTimestampMonthDayYearHourMinute": {
+ "12hour": "MMM d yyyy, h:mm aaa",
+ "24hour": "MMM d yyyy, HH:mm"
+ },
+ "formattedTimestampMonthDay": "MMM d",
+ "formattedTimestampFilename": {
+ "12hour": "MM-dd-yy-h-mm-ss-a",
+ "24hour": "MM-dd-yy-HH-mm-ss"
+ },
+ "inProgress": "Izpilda",
+ "invalidStartTime": "Nederīgs sākuma laiks",
+ "invalidEndTime": "Nederīgs beigu laiks",
+ "untilForRestart": "Līdz Frigate pārstartējas.",
+ "untilRestart": "Līdz pārstartēšanai",
+ "ago": "{{timeAgo}} pirms",
+ "justNow": "Nupat"
+ },
+ "unit": {
+ "speed": {
+ "mph": "mp/h",
+ "kph": "km/h"
+ },
+ "length": {
+ "feet": "Pēda",
+ "meters": "metri"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/stundā",
+ "mbph": "MB/stundā",
+ "gbph": "GB/stundā"
+ }
+ },
+ "label": {
+ "back": "Atgriezties",
+ "hide": "Paslēpt {{item}}",
+ "show": "Rādīt {{item}}",
+ "ID": "ID",
+ "none": "Nav",
+ "all": "Viss"
+ },
+ "list": {
+ "two": "{{0}} un {{1}}",
+ "many": "{{items}}, un {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Pēc izvēles",
+ "internalID": "Iekšējais frigates identifikators, ko izmanto konfigurācijā un datubāzē"
+ },
+ "button": {
+ "apply": "Apstiprināt",
+ "reset": "Atiestatīt",
+ "done": "Gatavs",
+ "enabled": "Ieslēgts",
+ "enable": "Ieslēgt",
+ "disabled": "Izslēgts",
+ "disable": "Izslēgt",
+ "save": "Saglabāt",
+ "saving": "Saglabā…",
+ "cancel": "Atcelt",
+ "close": "Aizvērt",
+ "copy": "Kopēt",
+ "back": "Atpakaļ",
+ "history": "Vēsture",
+ "fullscreen": "Pilnekrāna režīms",
+ "exitFullscreen": "Iziet no pilnekrāna režīma",
+ "pictureInPicture": "Attēls attēlā",
+ "twoWayTalk": "Divvirzienu saruna",
+ "cameraAudio": "Kameras Audio",
+ "on": "Iesl",
+ "off": "Izsl",
+ "edit": "Labot",
+ "copyCoordinates": "Kopēt koordinātas",
+ "delete": "Dzēst",
+ "yes": "Jā",
+ "no": "Nē",
+ "download": "Lejupielādēt",
+ "info": "Informācija",
+ "suspended": "Apturēts",
+ "unsuspended": "Atjaunot",
+ "play": "Atskaņot",
+ "unselect": "Noņemt izvēlēto",
+ "export": "Eksportēt",
+ "deleteNow": "Izdzēst tagad",
+ "next": "Nākamais",
+ "continue": "Turpināt"
+ },
+ "menu": {
+ "system": "Sistēma",
+ "systemMetrics": "Sistēmas rādītāji",
+ "configuration": "Konfigurācija",
+ "systemLogs": "Sistēmas žurnāli",
+ "settings": "Iestatījumi",
+ "configurationEditor": "Konfigurācijas redaktors",
+ "languages": "Valodas",
+ "language": {
+ "en": "English (angļu)",
+ "es": "Español (spāņu)",
+ "zhCN": "简体中文 (Vienkāršotā ķīniešu)",
+ "hi": "हिन्दी (hindi)",
+ "fr": "Français (Franču)",
+ "ar": "العربية (Arābu)",
+ "pt": "Português (Portugāļu)",
+ "ptBR": "Português brasileiro (Brazīlijas portugāļu)",
+ "ru": "Русский (Krievu)",
+ "de": "Deutsch (Vācu)",
+ "ja": "日本語 (Japāņu)",
+ "tr": "Türkçe (Turku)",
+ "it": "Italiano (Itāļu)",
+ "nl": "Nederlands (Nīderlandiešu)",
+ "sv": "Svenska (Zviedru)",
+ "cs": "Čeština (Čehu)",
+ "nb": "Norsk Bokmål (Norvēģu Bokmål)",
+ "ko": "한국어 (Korejiešu)",
+ "vi": "Tiếng Việt (Vjetnamiešu)",
+ "fa": "فارسی (Persiešu)",
+ "pl": "Polski (Poļu)",
+ "uk": "Українська (Ukraiņu)",
+ "he": "עברית (Ebreju)",
+ "el": "Ελληνικά (Grieķu)",
+ "ro": "Română (Rumāņu)",
+ "hu": "Magyar (Ungāru)",
+ "fi": "Suomi (Somu)",
+ "da": "Dansk (Dāņu)",
+ "sk": "Slovenčina (Slovāku)",
+ "yue": "粵語 (Kantonas)",
+ "th": "ไทย (Taju)",
+ "ca": "Català (Katalāņu)",
+ "sr": "Српски (Serbu)",
+ "sl": "Slovenščina (Slovēņu)",
+ "lt": "Lietuvių (Lietuviešu)",
+ "bg": "Български (Bulgāru)",
+ "gl": "Galego (Galisiešu)",
+ "id": "Bahasa Indonesia (Indonēziešu)",
+ "ur": "اردو (urdu)",
+ "withSystem": {
+ "label": "Izmantojiet sistēmas iestatījumus valodai"
+ }
+ },
+ "appearance": "Izskats",
+ "darkMode": {
+ "label": "Tumšais režīms",
+ "light": "Gaišs",
+ "dark": "Tumšs",
+ "withSystem": {
+ "label": "Izmantojiet sistēmas iestatījumus gaišajam vai tumšajam režīmam"
+ }
+ },
+ "withSystem": "Sistēma",
+ "theme": {
+ "label": "Tēma",
+ "blue": "Zila",
+ "green": "Zaļa",
+ "nord": "Ziemeļu",
+ "red": "Sarkana",
+ "highcontrast": "Augsta kontrasta",
+ "default": "Noklusējuma"
+ },
+ "help": "Palīdzība",
+ "documentation": {
+ "title": "Dokumentācija",
+ "label": "Frigates dokumentācija"
+ },
+ "restart": "Restartēt Frigate",
+ "live": {
+ "title": "Tiešraide",
+ "allCameras": "Visas kameras",
+ "cameras": {
+ "title": "Kameras",
+ "count_zero": "{{count}}kameras",
+ "count_one": "{{count}}kamera",
+ "count_other": "{{count}}kameras"
+ }
+ },
+ "review": "Pārskats",
+ "explore": "Meklēt notikumus",
+ "export": "Eksportēt",
+ "uiPlayground": "Interfeisa testēšanas vide",
+ "faceLibrary": "Seju bibliotēka",
+ "classification": "Atpazīšana",
+ "user": {
+ "title": "Lietotājs",
+ "account": "Konts",
+ "current": "Pašreizējais lietotājs: {{user}}",
+ "anonymous": "anonīms",
+ "logout": "Iziet",
+ "setPassword": "Izveidot paroli"
+ }
+ },
+ "toast": {
+ "copyUrlToClipboard": "Adrese nokopēta.",
+ "save": {
+ "title": "Saglabāt",
+ "error": {
+ "title": "Neizdevās saglabāt konfigurācijas izmaiņas: {{errorMessage}}",
+ "noMessage": "Neizdevās saglabāt konfigurācijas izmaiņas"
+ }
+ }
+ },
+ "role": {
+ "title": "Loma",
+ "admin": "Administrators",
+ "viewer": "Skatītājs",
+ "desc": "Administratoriem ir pilna piekļuve visām Frigate funkcijām. Skatītāji var skatīt tikai kameras, skatāmos elementus un arhivētos ierakstus."
+ },
+ "pagination": {
+ "label": "lappuse",
+ "previous": {
+ "title": "Iepriekšējais",
+ "label": "Pāriet uz iepriekšējo lapu"
+ },
+ "next": {
+ "title": "Nākamā",
+ "label": "Dodieties uz nākamo lapu"
+ },
+ "more": "Vairāk lapas"
+ },
+ "accessDenied": {
+ "documentTitle": "Piekļuve liegta - Frigate",
+ "title": "Piekļuve liegta",
+ "desc": "Jums nav atļaujas skatīt šo lapu."
+ },
+ "notFound": {
+ "documentTitle": "Nav atrasts - Frigate",
+ "title": "404",
+ "desc": "Lapa nav atrasta"
+ },
+ "selectItem": "Izvēlēties {{item}}",
+ "readTheDocumentation": "Laslīt dokumentāciju",
+ "information": {
+ "pixels": "{{area}}px"
+ }
+}
diff --git a/web/public/locales/lv/components/auth.json b/web/public/locales/lv/components/auth.json
new file mode 100644
index 000000000..b8b99fa54
--- /dev/null
+++ b/web/public/locales/lv/components/auth.json
@@ -0,0 +1,16 @@
+{
+ "form": {
+ "user": "Lietotājvārds",
+ "password": "Parole",
+ "login": "Pieteikties",
+ "firstTimeLogin": "Vai mēģināt pieteikties pirmo reizi? Jūsu akreditācijas dati ir norādīti Frigate žurnālos.",
+ "errors": {
+ "usernameRequired": "Nepieciešams lietotājvārds",
+ "passwordRequired": "Nepieciešams ievadīt paroli",
+ "rateLimit": "Pārsniegts mēģinājumu skaits. Lūdzu, mēģiniet vēlreiz vēlāk.",
+ "loginFailed": "Pieteikšanās neizdevās",
+ "unknownError": "Nezināma kļūda. Pārbaudiet žurnālu.",
+ "webUnknownError": "Nezināma kļūda. Pārbaudiet konsoles žurnālus."
+ }
+ }
+}
diff --git a/web/public/locales/lv/components/camera.json b/web/public/locales/lv/components/camera.json
new file mode 100644
index 000000000..d061f554d
--- /dev/null
+++ b/web/public/locales/lv/components/camera.json
@@ -0,0 +1,86 @@
+{
+ "group": {
+ "label": "Kameru grupas",
+ "add": "Pievienot kameru grupu",
+ "edit": "Rediģēt kameru grupu",
+ "delete": {
+ "label": "Dzēst kameru grupu",
+ "confirm": {
+ "title": "Apstiprināt dzēšanu",
+ "desc": "Vai esi pārliecināts, ka vēlies izdzēst kameru grupu {{name}}?"
+ }
+ },
+ "name": {
+ "label": "Nosaukums",
+ "placeholder": "Ievadiet vārdu…",
+ "errorMessage": {
+ "mustLeastCharacters": "Kameru grupas nosaukumam jāsastāv no vismaz 2 rakstzīmēm.",
+ "exists": "Kameru grupas nosaukums jau pastāv.",
+ "nameMustNotPeriod": "Kameru grupas nosaukumā nedrīkst būt punkts.",
+ "invalid": "Nederīgs kameru grupas nosaukums."
+ }
+ },
+ "cameras": {
+ "label": "Kameras",
+ "desc": "Atlasiet kameras šai grupai."
+ },
+ "icon": "Ikona",
+ "success": "Kameru grupa ({{name}}) ir saglabāta.",
+ "camera": {
+ "birdseye": "Birds-eye",
+ "setting": {
+ "label": "Kameras straumēšanas iestatījumi",
+ "title": "Straumēšanas iestatījumi{{cameraName}}",
+ "desc": "Mainiet šīs kameru grupas paneļa tiešraides straumes iestatījumus. Šie iestatījumi ir atkarīgi no ierīces/pārlūkprogrammas.",
+ "audioIsAvailable": "Šai straumei ir pieejams audio",
+ "audioIsUnavailable": "Šai straumei nav pieejams audio.",
+ "audio": {
+ "tips": {
+ "title": "Šai straumei audio ir jāizvada no kameras un tas ir jākonfigurē go2rtc."
+ }
+ },
+ "stream": "Straume",
+ "placeholder": "Izvēlieties straumi",
+ "streamMethod": {
+ "label": "Straumēšanas metode",
+ "placeholder": "Izvēlieties straumēšanas metodi",
+ "method": {
+ "noStreaming": {
+ "label": "Nav straumēšanas",
+ "desc": "Kameru attēli tiks atjaunināti tikai reizi minūtē, bez tiešraides straumēšanas."
+ },
+ "smartStreaming": {
+ "label": "Viedā straumēšana (ieteicams)",
+ "desc": "Viedā straumēšana atjauninās kameras attēlu reizi minūtē, ja netiks konstatēta aktivitāte, lai taupītu joslas platumu un resursus. Kad tiks konstatēta aktivitāte, attēls nemanāmi pārslēdzas uz tiešraides straumēšanu."
+ },
+ "continuousStreaming": {
+ "label": "Nepārtraukta straumēšana",
+ "desc": {
+ "title": "Kameras attēls vienmēr būs tiešraidē, kad tas būs redzams informācijas panelī, pat ja netiks konstatēta nekāda aktivitāte.",
+ "warning": "Nepārtraukta straumēšana var izraisīt lielu joslas platuma izmantošanu un veiktspējas problēmas. Izmantojiet to piesardzīgi."
+ }
+ }
+ }
+ },
+ "compatibilityMode": {
+ "label": "Saderības režīms",
+ "desc": "Iespējojiet šo opciju tikai tad, ja kameras tiešraides straumē tiek rādīti krāsu artefakti un attēla labajā pusē ir diagonāla līnija."
+ }
+ }
+ }
+ },
+ "debug": {
+ "options": {
+ "label": "Iestatījumi",
+ "title": "Iespējas",
+ "showOptions": "Rādīt Iespējas",
+ "hideOptions": "Paslēpt Iespējas"
+ },
+ "boundingBox": "Ierobežojošs rāmis",
+ "timestamp": "Laika zīmogs",
+ "zones": "Zonas",
+ "mask": "Maska",
+ "motion": "Kustība",
+ "regions": "Reģioni"
+ }
+}
diff --git a/web/public/locales/lv/components/dialog.json b/web/public/locales/lv/components/dialog.json
new file mode 100644
index 000000000..3f52bc65d
--- /dev/null
+++ b/web/public/locales/lv/components/dialog.json
@@ -0,0 +1,123 @@
+{
+ "restart": {
+ "title": "Vai esi pārliecināts, ka vēlies pārstartēt Frigati?",
+ "button": "Pārstartēt",
+ "restarting": {
+ "title": "Frigate tiek pārstartēta",
+ "content": "Šī lapa tiks atkārtoti ielādēta pēc {{countdown}} sekundēm.",
+ "button": "Atjaunot tagad"
+ }
+ },
+ "explore": {
+ "plus": {
+ "submitToPlus": {
+ "label": "Sūtīt uz Frigate+",
+ "desc": "Objekti vietās, no kurām vēlaties izvairīties, nav kļūdaini pozitīvi. To iesniegšana kā kļūdaini pozitīvi radīs modelim neskaidrības."
+ },
+ "review": {
+ "question": {
+ "label": "Apstipriniet šo tagu pakalpojumam Frigate Plus",
+ "ask_a": "Vai šis objekts{{label}}?",
+ "ask_an": "Vai šis objekts ir{{label}}?",
+ "ask_full": "Vai šis objekts{{untranslatedLabel}} ({{translatedLabel}})?"
+ },
+ "state": {
+ "submitted": "Iesniegts"
+ }
+ }
+ },
+ "video": {
+ "viewInHistory": "Skatīt vēsturē"
+ }
+ },
+ "export": {
+ "time": {
+ "fromTimeline": "Izvēlieties no laika skalas",
+ "lastHour_zero": "Pēdējās stundas",
+ "lastHour_one": "Pēdējās{{count}}stundas",
+ "lastHour_other": "Pēdējās {{count}} stundas",
+ "custom": "Pielāgots",
+ "start": {
+ "title": "Sākuma laiks",
+ "label": "Izvēlieties Sākuma laiks"
+ },
+ "end": {
+ "title": "Beigu laiks",
+ "label": "Atlasiet Beigu laiks"
+ }
+ },
+ "name": {
+ "placeholder": "Ievadiet eksporta nosaukumu"
+ },
+ "select": "Izvēlieties",
+ "export": "Eksportēt",
+ "selectOrExport": "Atlasīt vai Eksportēt",
+ "toast": {
+ "success": "Eksportēšana veiksmīgi sākta. Skatiet failu eksportēšanas lapā.",
+ "view": "Skatīt",
+ "error": {
+ "failed": "Neizdevās sākt eksportēšanu: {{error}}",
+ "endTimeMustAfterStartTime": "Beigu laikam ir jābūt pēc sākuma laika",
+ "noVaildTimeSelected": "Nav izvēlēts derīgs laika diapazons"
+ }
+ },
+ "fromTimeline": {
+ "saveExport": "Saglabāt Eksportu",
+ "previewExport": "Priekšskatīt Eksportu"
+ }
+ },
+ "streaming": {
+ "label": "Straume",
+ "restreaming": {
+ "disabled": "Šai kamerai nav iespējota atkārtota straumēšana.",
+ "desc": {
+ "title": "Konfigurējiet go2rtc, lai šai kamerai varētu piekļūt papildu tiešraides skatīšanās un audio opcijām."
+ }
+ },
+ "showStats": {
+ "label": "Rādīt straumes statistiku",
+ "desc": "Iespējojiet šo opciju, lai straumes statistika tiktu rādīta kā pārklājums kameras attēlam."
+ },
+ "debugView": "Atkļūdošanas režīms"
+ },
+ "search": {
+ "saveSearch": {
+ "label": "Saglabāt meklēšanu",
+ "desc": "Norādiet šīs saglabātās meklēšanas nosaukumu.",
+ "placeholder": "Ievadiet meklēšanas nosaukumu",
+ "overwrite": "{{searchName}} jau pastāv. Saglabājot, esošā vērtība tiks pārrakstīta.",
+ "success": "Meklēšanas ({{searchName}}) ir saglabāts.",
+ "button": {
+ "save": {
+ "label": "Saglabāt šo meklēšanu"
+ }
+ }
+ }
+ },
+ "recording": {
+ "confirmDelete": {
+ "title": "Apstipriniet dzēšanu",
+ "desc": {
+ "selected": "Vai tiešām vēlaties dzēst visus ierakstītos video, kas saistīti ar šo pārskata vienumu?detect straumes netika saņemti kadri, pārbaudiet kļūdu žurnālus."
+ },
+ "cameraDisabled": "Kamera ir izslēgta",
+ "stats": {
+ "streamType": {
+ "title": "Straumes veids:",
+ "short": "Tips"
+ },
+ "bandwidth": {
+ "title": "Joslas platums:",
+ "short": "Joslas platums"
+ },
+ "latency": {
+ "title": "Latentums:",
+ "value": "{{seconds}} sekundes",
+ "short": {
+ "title": "Latentums",
+ "value": "{{seconds}} sek"
+ }
+ },
+ "totalFrames": "Kopējais kadru skaits:",
+ "droppedFrames": {
+ "title": "Izlaisti kadri:",
+ "short": {
+ "title": "Izlaisti",
+ "value": "{{droppedFrames}} kadri"
+ }
+ },
+ "decodedFrames": "Dekodētie kadri:",
+ "droppedFrameRate": "Kadru nomaiņas ātruma kritums:"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "Kadrs veiksmīgi iesniegts pakalpojumam Frigate+"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "Neizdevās iesniegt kadru Frigate+"
+ }
+ }
+}
diff --git a/web/public/locales/lv/objects.json b/web/public/locales/lv/objects.json
new file mode 100644
index 000000000..981d5cb44
--- /dev/null
+++ b/web/public/locales/lv/objects.json
@@ -0,0 +1,19 @@
+{
+ "person": "Persona",
+ "bicycle": "Velosipēds",
+ "car": "Automašīna",
+ "motorcycle": "Motocikls",
+ "airplane": "Lidmašīna",
+ "bus": "Autobuss",
+ "train": "Vilciens",
+ "package": "Paciņa",
+ "bbq_grill": "Grils",
+ "amazon": "Amazon",
+ "usps": "USPS",
+ "ups": "UPS",
+ "fedex": "FedEx",
+ "dhl": "DHL",
+ "postnl": "PostNL",
+ "dpd": "DPD",
+ "boat": "Laiva"
+}
diff --git a/web/public/locales/lv/views/classificationModel.json b/web/public/locales/lv/views/classificationModel.json
new file mode 100644
index 000000000..5d26d5b74
--- /dev/null
+++ b/web/public/locales/lv/views/classificationModel.json
@@ -0,0 +1,36 @@
+{
+ "documentTitle": "Klassifikācijas modeļi",
+ "details": {
+ "scoreInfo": "Rezultāts atbilst vidējai klasifikācijas ticamībai no visām objekta detektēšanas reizēm.",
+ "none": "Nav",
+ "unknown": "Nezināms"
+ },
+ "description": {
+ "invalidName": "Nederīgs nosaukums. Nosaukumi drīkst saturēt tikai burtus, ciparus, atstarpes, apostrofus, pasvītras un defises."
+ },
+ "button": {
+ "deleteClassificationAttempts": "Dzēst klasifikācijas attēlus",
+ "renameCategory": "Pārdēvēt klasi",
+ "deleteCategory": "Dzēst klasi",
+ "deleteImages": "Dzēst attēlus"
+ },
+ "wizard": {
+ "step3": {
+ "training": {
+ "title": "Trenē modeli",
+ "description": "Tavs modelis tiek trenēts. Aizver šo paziņojumu, un tavs modelis tiks izmantots, tiklīdz trenēšana ir pabeigta."
+ },
+ "retryGenerate": "Atkārtot ģenerēšanu",
+ "classifying": "Klasificē un trenē...",
+ "trainingStarted": "Trenēšana veiksmīgi uzsākta",
+ "errors": {
+ "generateFailed": "Neizdevās ģenerēt piemērus: {{error}}",
+ "generationFailed": "Ģenerēšana neizdevās. Mēģini vēlreiz.",
+ "classifyFailed": "Neizdevās klasificēt attēlus: {{error}}"
+ }
+ }
+ },
+ "train": {
+ "titleShort": "Pēdējās"
+ }
+}
diff --git a/web/public/locales/lv/views/configEditor.json b/web/public/locales/lv/views/configEditor.json
new file mode 100644
index 000000000..286da8e9a
--- /dev/null
+++ b/web/public/locales/lv/views/configEditor.json
@@ -0,0 +1,18 @@
+{
+ "documentTitle": "Konfigurācijas rediģēšana - Frigate",
+ "configEditor": "Konfigurācijas redaktors",
+ "safeConfigEditor": "Konfigurācijas redaktors (drošais režīms)",
+ "safeModeDescription": "Frigate ir drošajā režīmā konfigurācijas pārbaudes kļūdas dēļ.",
+ "copyConfig": "Kopēt konfigurāciju",
+ "saveAndRestart": "Saglabāt un pārstartēt",
+ "saveOnly": "Tikai saglabāt",
+ "confirm": "Vai iziet, nesaglabājot?",
+ "toast": {
+ "success": {
+ "copyToClipboard": "Konfigurācija ir kopēta starpliktuvē."
+ },
+ "error": {
+ "savingError": "Saglabājot konfigurāciju, radās kļūda"
+ }
+ }
+}
diff --git a/web/public/locales/lv/views/events.json b/web/public/locales/lv/views/events.json
new file mode 100644
index 000000000..77d4d34e5
--- /dev/null
+++ b/web/public/locales/lv/views/events.json
@@ -0,0 +1,61 @@
+{
+ "alerts": "Paziņojumi",
+ "detections": "Atklājumi",
+ "motion": {
+ "label": "Kustība",
+ "only": "Tikai kustība"
+ },
+ "allCameras": "Visas kameras",
+ "empty": {
+ "alert": "Nav paziņojumu, kurus pārskatīt",
+ "detection": "Nav apskatāmu konstatējumu",
+ "motion": "Nav atrasti kustības dati"
+ },
+ "timeline": "Laika skala",
+ "timeline.aria": "Izvēlieties laika skalu",
+ "zoomIn": "Pietuvināt",
+ "zoomOut": "Tālināt",
+ "events": {
+ "label": "Notikumi",
+ "aria": "Izvēlieties notikumus",
+ "noFoundForTimePeriod": "Šajā laika periodā nav atrasts neviens notikums."
+ },
+ "detail": {
+ "label": "Detaļas",
+ "noDataFound": "Nav detalizētu datu pārskatīšanai",
+ "aria": "Pārslēgt detalizēto skatu",
+ "trackedObject_one": "{{count}} objekts",
+ "trackedObject_other": "{{count}} objekti",
+ "noObjectDetailData": "Nav pieejami objekta detalizēti dati.",
+ "settings": "Detaļas skata iestatījumi",
+ "alwaysExpandActive": {
+ "title": "Vienmēr izvērst aktīvs",
+ "desc": "Vienmēr izvērsiet aktīvā pārskata vienuma objekta informāciju, ja tāda ir pieejama."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Izsekots punkts",
+ "clickToSeek": "Noklikšķiniet, lai pārietu uz šo laiku"
+ },
+ "documentTitle": "Pārskats - Frigate",
+ "recordings": {
+ "documentTitle": "Ieraksti - Frigate"
+ },
+ "calendarFilter": {
+ "last24Hours": "Pēdējās 24 stundas"
+ },
+ "markAsReviewed": "Atzīmēt kā pārskatītu",
+ "markTheseItemsAsReviewed": "Atzīmēt šos vienumus kā pārskatītus",
+ "newReviewItems": {
+ "label": "Skatīt jaunus atsauksmju vienumus",
+ "button": "Jauni vienumi, kas jāpārskata"
+ },
+ "selected_one": "atlasīts {{count}}",
+ "selected_other": "atlasīts {{count}}",
+ "select_all": "Viss",
+ "camera": "Kamera",
+ "detected": "atklāts",
+ "normalActivity": "Normāls",
+ "needsReview": "Nepieciešama pārskatīšana",
+ "securityConcern": "Drošības jautājums"
+}
diff --git a/web/public/locales/lv/views/explore.json b/web/public/locales/lv/views/explore.json
new file mode 100644
index 000000000..63a2d2cbc
--- /dev/null
+++ b/web/public/locales/lv/views/explore.json
@@ -0,0 +1,49 @@
+{
+ "documentTitle": "Notikumu meklēšana - Frigate",
+ "generativeAI": "Ģeneratīvs AI",
+ "exploreMore": "Paskatīt vairāk objektu{{label}}",
+ "details": {
+ "timestamp": "Laika zīmogs"
+ },
+ "exploreIsUnavailable": {
+ "title": "Notikumu meklēšana nav pieejama",
+ "embeddingsReindexing": {
+ "context": "Meklēšana būs pieejama pēc tam, kad būs pabeigta izsekoto objektu atkārtota indeksēšana.",
+ "startingUp": "Notiek palaišana…",
+ "estimatedTime": "Paredzamais atlikušais laiks:"
+ }
+ },
+ "itemMenu": {
+ "findSimilar": {
+ "label": "Atrast līdzīgus",
+ "aria": "Atrast līdzīgus izsekotos priekšmetus"
+ },
+ "submitToPlus": {
+ "label": "Iesniegt Frigate+",
+ "aria": "Iesniegt Frigate Plus"
+ },
+ "viewInHistory": {
+ "label": "Atrast vēsturē"
+ },
+ "deleteTrackedObject": {
+ "label": "Dzēst šo izsekoto priekšmetu"
+ }
+ },
+ "dialog": {
+ "confirmDelete": {
+ "title": "Apstiprināt dzēšanu"
+ }
+ },
+ "searchResult": {
+ "nextTrackedObject": "Nākamais izsekotais objekts",
+ "deleteTrackedObject": {
+ "toast": {
+ "success": "Izsekotais objekts veiksmīgi izdzēsts.",
+ "error": "Neizdevās izdzēst izsekoto objektu: {{errorMessage}}"
+ }
+ }
+ },
+ "aiAnalysis": {
+ "title": "MI analīze"
+ }
+}
diff --git a/web/public/locales/lv/views/exports.json b/web/public/locales/lv/views/exports.json
new file mode 100644
index 000000000..73209ce9e
--- /dev/null
+++ b/web/public/locales/lv/views/exports.json
@@ -0,0 +1,23 @@
+{
+ "documentTitle": "Eksportēt - Frigate",
+ "search": "Meklēt",
+ "noExports": "Eksporti nav atrasti",
+ "deleteExport": "Dzēst eksportu",
+ "deleteExport.desc": "Vai esi pārliecināts, ka vēlies izdzēst{{exportName}}?",
+ "editExport": {
+ "title": "Pārdēvēt eksportu",
+ "desc": "Ievadiet jaunu nosaukumu šim eksportam.",
+ "saveExport": "Saglabāt eksportu"
+ },
+ "tooltip": {
+ "shareExport": "Kopīgot eksportu",
+ "downloadVideo": "Lejupielādēt video",
+ "editName": "Rediģēt nosaukumu",
+ "deleteExport": "Eksporta dzēšana"
+ },
+ "toast": {
+ "error": {
+ "renameExportFailed": "Neizdevās pārdēvēt eksporta failu: {{errorMessage}}"
+ }
+ }
+}
diff --git a/web/public/locales/lv/views/faceLibrary.json b/web/public/locales/lv/views/faceLibrary.json
new file mode 100644
index 000000000..f6e254c22
--- /dev/null
+++ b/web/public/locales/lv/views/faceLibrary.json
@@ -0,0 +1,93 @@
+{
+ "description": {
+ "addFace": "Pievienojiet savai seju bibliotēkai jaunu kolekciju, augšupielādējot savu pirmo attēlu.",
+ "placeholder": "Ievadi kolekcijas nosaukumu",
+ "invalidName": "Nederīgs nosaukums. Nosaukumi drīkst saturēt tikai burtus, ciparus, atstarpes, apostrofus, pasvītras un defises."
+ },
+ "details": {
+ "timestamp": "Laika zīmogs",
+ "unknown": "Nezināms",
+ "scoreInfo": "Rezultāts ir visu seju rezultāta vidējais, svērts pēc sejas izmēra katrā attēlā."
+ },
+ "documentTitle": "Seju bibliotēka - Frigate",
+ "uploadFaceImage": {
+ "title": "Augšupielādējiet sejas attēlu",
+ "desc": "Augšupielādējiet attēlu, lai skenētu sejas un iekļautu to lapā {{pageToggle}}"
+ },
+ "collections": "Kolekcijas",
+ "createFaceLibrary": {
+ "new": "Izveidojiet jaunu seju",
+ "nextSteps": "Lai izveidotu stabilu pamatu:{{label}}?",
"ask_a": "Er dette objektet en {{label}}?",
"ask_full": "Er dette objekt en {{untranslatedLabel}} ({{translatedLabel}})?"
@@ -56,12 +56,13 @@
}
},
"toast": {
- "success": "Eksporten startet. Se filen i /exports-mappen.",
+ "success": "Eksport startet. Se filen på eksportsiden.",
"error": {
"failed": "Klarte ikke å starte eksport: {{error}}",
"noVaildTimeSelected": "Ingen gyldig tidsperiode valgt",
"endTimeMustAfterStartTime": "Sluttid må være etter starttid"
- }
+ },
+ "view": "Vis"
},
"fromTimeline": {
"previewExport": "Forhåndsvis eksport",
@@ -117,7 +118,16 @@
"button": {
"export": "Eksportér",
"markAsReviewed": "Merk som inspisert",
- "deleteNow": "Slett nå"
+ "deleteNow": "Slett nå",
+ "markAsUnreviewed": "Merk som ikke inspisert"
}
+ },
+ "imagePicker": {
+ "selectImage": "Velg et sporet objekts miniatyrbilde",
+ "search": {
+ "placeholder": "Søk etter (under-)etikett..."
+ },
+ "noImages": "Ingen miniatyrbilder funnet for dette kameraet",
+ "unknownLabel": "Lagret utløserbilde"
}
}
diff --git a/web/public/locales/nb-NO/components/filter.json b/web/public/locales/nb-NO/components/filter.json
index 5bcbf5d08..eb0684619 100644
--- a/web/public/locales/nb-NO/components/filter.json
+++ b/web/public/locales/nb-NO/components/filter.json
@@ -1,30 +1,30 @@
{
"filter": "Filter",
"labels": {
- "label": "Merkelapper",
+ "label": "Etiketter",
"all": {
- "title": "Alle masker / soner",
- "short": "Merkelapper"
+ "title": "Alle etiketter",
+ "short": "Etiketter"
},
"count": "{{count}} merkelapper",
- "count_other": "{{count}} Merkelapper",
- "count_one": "{{count}} Merkelapp"
+ "count_other": "{{count}} Etiketter",
+ "count_one": "{{count}} Etikett"
},
"features": {
"hasVideoClip": "Har et videoklipp",
"submittedToFrigatePlus": {
"label": "Sendt til Frigate+",
- "tips": "Du må først filtrere på sporede objekter som har et øyeblikksbilde.detekt strømmen, sjekk feilloggene"
+ "desc": "Ingen bilder er mottatt på {{cameraName}} detekt-strømmen, sjekk feilloggene"
},
"cameraDisabled": "Kameraet er deaktivert",
"toast": {
diff --git a/web/public/locales/nb-NO/objects.json b/web/public/locales/nb-NO/objects.json
index d292b63b8..5c7c5edd2 100644
--- a/web/public/locales/nb-NO/objects.json
+++ b/web/public/locales/nb-NO/objects.json
@@ -101,7 +101,7 @@
"raccoon": "Vaskebjørn",
"robot_lawnmower": "Robotgressklipper",
"waste_bin": "Avfallsbeholder",
- "on_demand": "På forespørsel",
+ "on_demand": "Manuelt opptak",
"face": "Ansikt",
"license_plate": "Kjennemerke",
"package": "Pakke",
diff --git a/web/public/locales/nb-NO/views/classificationModel.json b/web/public/locales/nb-NO/views/classificationModel.json
new file mode 100644
index 000000000..e7ee73f08
--- /dev/null
+++ b/web/public/locales/nb-NO/views/classificationModel.json
@@ -0,0 +1,185 @@
+{
+ "documentTitle": "Klassifiseringsmodeller - Frigate",
+ "button": {
+ "deleteClassificationAttempts": "Slett klassifiseringsbilder",
+ "renameCategory": "Omdøp klasse",
+ "deleteCategory": "Slett klasse",
+ "deleteImages": "Slett bilder",
+ "trainModel": "Tren modell",
+ "addClassification": "Legg til klassifisering",
+ "deleteModels": "Slett modeller",
+ "editModel": "Rediger modell"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Klasse slettet",
+ "deletedImage": "Bilder slettet",
+ "categorizedImage": "Klassifiserte bildet",
+ "trainedModel": "Modellen ble trent.",
+ "trainingModel": "Modelltrening startet.",
+ "deletedModel_one": "{{count}} modell ble slettet",
+ "deletedModel_other": "{{count}} modeller ble slettet",
+ "updatedModel": "Modellkonfigurasjonen ble oppdatert",
+ "renamedCategory": "Klassen ble omdøpt til {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Kunne ikke slette: {{errorMessage}}",
+ "deleteCategoryFailed": "Kunne ikke slette klasse: {{errorMessage}}",
+ "categorizeFailed": "Kunne ikke klassifisere bilde: {{errorMessage}}",
+ "trainingFailed": "Modelltrening mislyktes. Sjekk Frigate-loggene for detaljer.",
+ "deleteModelFailed": "Kunne ikke slette modell: {{errorMessage}}",
+ "trainingFailedToStart": "Kunne ikke starte modelltrening: {{errorMessage}}",
+ "updateModelFailed": "Kunne ikke oppdatere modell: {{errorMessage}}",
+ "renameCategoryFailed": "Kunne ikke omdøpe klasse: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Slett klasse",
+ "desc": "Er du sikker på at du vil slette klassen {{name}}? Dette vil permanent slette alle tilknyttede bilder og kreve at modellen trenes på nytt.",
+ "minClassesTitle": "Kan ikke slette klasse",
+ "minClassesDesc": "En klassifiseringsmodell må ha minst 2 klasser. Legg til en ny klasse før du sletter denne."
+ },
+ "deleteDatasetImages": {
+ "title": "Slett datasettbilder",
+ "desc": "Er du sikker på at du vil slette {{count}} bilder fra {{dataset}}? Denne handlingen kan ikke angres og krever at modellen trenes på nytt."
+ },
+ "deleteTrainImages": {
+ "title": "Slett treningsbilder",
+ "desc": "Er du sikker på at du vil slette {{count}} bilder? Denne handlingen kan ikke angres."
+ },
+ "renameCategory": {
+ "title": "Omdøp klasse",
+ "desc": "Skriv inn et nytt navn for {{name}}. Du må trene modellen på nytt for at navneendringen skal tre i kraft."
+ },
+ "description": {
+ "invalidName": "Ugyldig navn. Navn kan kun inneholde bokstaver, tall, mellomrom, apostrof, understrek og bindestrek."
+ },
+ "train": {
+ "title": "Nylige klassifiseringer",
+ "aria": "Velg nylige klassifiseringer",
+ "titleShort": "Nylige"
+ },
+ "categories": "Klasser",
+ "createCategory": {
+ "new": "Opprett ny klasse"
+ },
+ "categorizeImageAs": "Klassifiser bilde som:",
+ "categorizeImage": "Klassifiser bilde",
+ "noModels": {
+ "object": {
+ "title": "Ingen objektklassifiseringsmodeller",
+ "description": "Opprett en tilpasset modell for å klassifisere oppdagede objekter.",
+ "buttonText": "Opprett objektmodell"
+ },
+ "state": {
+ "title": "Ingen tilstandsklassifiseringsmodeller",
+ "description": "Opprett en tilpasset modell for å overvåke og klassifisere tilstandsendringer i spesifikke kamerasoner.",
+ "buttonText": "Opprett tilstandsmodell"
+ }
+ },
+ "wizard": {
+ "title": "Opprett ny klassifisering",
+ "steps": {
+ "nameAndDefine": "Navn og definér",
+ "stateArea": "Tilstandsområde",
+ "chooseExamples": "Velg eksempler"
+ },
+ "step1": {
+ "description": "Tilstandsmodeller overvåker faste kamerasoner for endringer (f.eks. dør åpen/lukket). Objektmodeller legger til klassifiseringer for oppdagede objekter (f.eks. kjente dyr, bud, osv.).",
+ "name": "Navn",
+ "namePlaceholder": "Skriv inn modellnavn...",
+ "type": "Type",
+ "typeState": "Tilstand",
+ "typeObject": "Objekt",
+ "objectLabel": "Objektetikett",
+ "objectLabelPlaceholder": "Velg objekttype...",
+ "classificationType": "Klassifiseringstype",
+ "classificationTypeTip": "Lær om klassifiseringstyper",
+ "classificationTypeDesc": "Underetiketter legger til ekstra tekst på objektetiketten (f.eks. 'Person: Posten'). Attributter er søkbare metadata som lagres separat i objektets metadata.",
+ "classificationSubLabel": "Underetikett",
+ "classificationAttribute": "Attributt",
+ "classes": "Klasser",
+ "classesTip": "Lær om klasser",
+ "classesStateDesc": "Definer de ulike tilstandene kamerasonen kan være i. For eksempel: 'åpen' og 'lukket' for en garasjeport.",
+ "classesObjectDesc": "Definer klassene du vil klassifisere oppdagede objekter i. For eksempel: 'bud', 'beboer', 'fremmed' for personklassifisering.",
+ "classPlaceholder": "Skriv inn klassenavn...",
+ "errors": {
+ "nameRequired": "Modellnavn er påkrevd",
+ "nameLength": "Modellnavn må være på 64 tegn eller mindre",
+ "nameOnlyNumbers": "Modellnavn kan ikke bare inneholde tall",
+ "classRequired": "Minst én klasse er påkrevd",
+ "classesUnique": "Klassenavn må være unike",
+ "stateRequiresTwoClasses": "Tilstandsmodeller krever minst 2 klasser",
+ "objectLabelRequired": "Velg en objektetikett",
+ "objectTypeRequired": "Velg en klassifiseringstype",
+ "noneNotAllowed": "Klassen 'ingen' er ikke tillatt"
+ },
+ "states": "Tilstander"
+ },
+ "step2": {
+ "description": "Velg kameraer og definer området som skal overvåkes for hvert kamera. Modellen vil klassifisere tilstanden til disse områdene.",
+ "cameras": "Kameraer",
+ "selectCamera": "Velg kamera",
+ "noCameras": "Klikk + for å legge til kameraer",
+ "selectCameraPrompt": "Velg et kamera fra listen for å definere overvåkingsområdet"
+ },
+ "step3": {
+ "selectImagesPrompt": "Velg alle bilder med: {{className}}",
+ "selectImagesDescription": "Klikk på bilder for å velge dem. Klikk Fortsett når du er ferdig med denne klassen.",
+ "generating": {
+ "title": "Genererer eksempelbilder",
+ "description": "Frigate henter representative bilder fra opptakene dine. Dette kan ta litt tid..."
+ },
+ "training": {
+ "title": "Trener modell",
+ "description": "Modellen din trenes i bakgrunnen. Lukk dette vinduet, så starter modellen når treningen er ferdig."
+ },
+ "retryGenerate": "Prøv å generere på nytt",
+ "noImages": "Ingen eksempelbilder generert",
+ "classifying": "Klassifiserer og trener...",
+ "trainingStarted": "Trening startet",
+ "errors": {
+ "noCameras": "Ingen kameraer konfigurert",
+ "noObjectLabel": "Ingen objektetikett valgt",
+ "generateFailed": "Kunne ikke generere eksempler: {{error}}",
+ "generationFailed": "Generering mislyktes. Prøv igjen.",
+ "classifyFailed": "Kunne ikke klassifisere bilder: {{error}}"
+ },
+ "generateSuccess": "Eksempelbilder ble generert",
+ "allImagesRequired_one": "Vennligst klassifiser alle bildene. {{count}} bilde gjenstår.",
+ "allImagesRequired_other": "Vennligst klassifiser alle bildene. {{count}} bilder gjenstår.",
+ "modelCreated": "Modellen ble opprettet. Bruk visningen Nylige klassifiseringer for å legge til bilder for manglende tilstander, og tren deretter modellen.",
+ "missingStatesWarning": {
+ "title": "Manglende tilstandseksempler",
+ "description": "Det anbefales å velge eksempler for alle tilstander for å oppnå best mulig resultat. Du kan fortsette uten å velge alle tilstander, men modellen vil ikke bli trent før alle tilstander har bilder. Etter at du har gått videre, bruk visningen Nylige klassifiseringer for å klassifisere bilder for de manglende tilstandene, og tren deretter modellen."
+ }
+ }
+ },
+ "deleteModel": {
+ "title": "Slett klassifiseringsmodell",
+ "single": "Er du sikker på at du vil slette {{name}}? Dette vil permanent slette alle tilknyttede data, inkludert bilder og treningsdata. Denne handlingen kan ikke angres.",
+ "desc": "Er du sikker på at du vil slette {{count}} modell(er)? Dette vil permanent slette alle tilknyttede data, inkludert bilder og treningsdata. Denne handlingen kan ikke angres."
+ },
+ "menu": {
+ "objects": "Objekter",
+ "states": "Tilstander"
+ },
+ "details": {
+ "scoreInfo": "Score representerer gjennomsnittlig klassifiseringskonfidens på tvers av alle deteksjoner av dette objektet.",
+ "none": "Ingen",
+ "unknown": "Ukjent"
+ },
+ "tooltip": {
+ "trainingInProgress": "Modellen trenes nå",
+ "noNewImages": "Ingen nye bilder å trene på. Klassifiser flere bilder i datasettet først.",
+ "noChanges": "Ingen endringer i datasettet siden forrige trening.",
+ "modelNotReady": "Modellen er ikke klar til å trenes"
+ },
+ "edit": {
+ "title": "Rediger klassifiseringsmodell",
+ "descriptionState": "Rediger klassene for denne tilstandsklassifiseringsmodellen. Endringer vil kreve at modellen trenes på nytt.",
+ "descriptionObject": "Rediger objekttypen og klassifiseringstypen for denne objektklassifiseringsmodellen.",
+ "stateClassesInfo": "Merk: Endring av tilstandsklasser krever at modellen trenes på nytt med de oppdaterte klassene."
+ },
+ "none": "Ingen"
+}
diff --git a/web/public/locales/nb-NO/views/configEditor.json b/web/public/locales/nb-NO/views/configEditor.json
index 09f0b1c69..c0c9253fa 100644
--- a/web/public/locales/nb-NO/views/configEditor.json
+++ b/web/public/locales/nb-NO/views/configEditor.json
@@ -12,5 +12,7 @@
"copyConfig": "Kopier konfigurasjonen",
"saveAndRestart": "Lagre og omstart",
"saveOnly": "Kun lagre",
- "confirm": "Avslutt uten å lagre?"
+ "confirm": "Avslutt uten å lagre?",
+ "safeConfigEditor": "Konfigurasjonsredigering (Sikker modus)",
+ "safeModeDescription": "Frigate er i sikker modus grunnet en feil i validering av konfigurasjonen."
}
diff --git a/web/public/locales/nb-NO/views/events.json b/web/public/locales/nb-NO/views/events.json
index 70d24e20e..5e77f38ed 100644
--- a/web/public/locales/nb-NO/views/events.json
+++ b/web/public/locales/nb-NO/views/events.json
@@ -3,7 +3,11 @@
"empty": {
"alert": "Det er ingen varsler å inspisere",
"detection": "Det er ingen deteksjoner å inspisere",
- "motion": "Ingen bevegelsesdata funnet"
+ "motion": "Ingen bevegelsesdata funnet",
+ "recordingsDisabled": {
+ "title": "Opptak må være aktivert",
+ "description": "Inspeksjonselementer kan kun opprettes for et kamera når opptak er aktivert for det kameraet."
+ }
},
"timeline": "Tidslinje",
"events": {
@@ -23,7 +27,7 @@
},
"allCameras": "Alle kameraer",
"timeline.aria": "Velg tidslinje",
- "documentTitle": "Inspiser - Frigate",
+ "documentTitle": "Inspeksjon - Frigate",
"recordings": {
"documentTitle": "Opptak - Frigate"
},
@@ -34,5 +38,30 @@
"markTheseItemsAsReviewed": "Merk disse elementene som inspiserte",
"selected_one": "{{count}} valgt",
"selected_other": "{{count}} valgt",
- "detected": "detektert"
+ "detected": "detektert",
+ "suspiciousActivity": "Mistenkelig aktivitet",
+ "threateningActivity": "Truende aktivitet",
+ "detail": {
+ "noDataFound": "Ingen detaljer å inspisere",
+ "aria": "Vis/skjul detaljvisning",
+ "trackedObject_one": "{{count}} objekt",
+ "trackedObject_other": "{{count}} objekter",
+ "noObjectDetailData": "Ingen detaljdata for objektet tilgjengelig.",
+ "label": "Detalj",
+ "settings": "Detaljvisning – innstillinger",
+ "alwaysExpandActive": {
+ "desc": "Utvid alltid objektdetaljene for det aktive gjennomgangselementet når tilgjengelig.",
+ "title": "Utvid alltid for aktive"
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Sporingspunkt",
+ "clickToSeek": "Klikk for å gå til dette tidspunktet"
+ },
+ "zoomIn": "Zoom inn",
+ "zoomOut": "Zoom ut",
+ "normalActivity": "Normal",
+ "needsReview": "Trenger inspeksjon",
+ "securityConcern": "Sikkerhetsrisiko",
+ "select_all": "Alle"
}
diff --git a/web/public/locales/nb-NO/views/explore.json b/web/public/locales/nb-NO/views/explore.json
index e95dbfda2..a9fe5230a 100644
--- a/web/public/locales/nb-NO/views/explore.json
+++ b/web/public/locales/nb-NO/views/explore.json
@@ -19,7 +19,7 @@
"visionModel": "Visjonsmodell",
"visionModelFeatureExtractor": "Funksjonsekstraktor for visjonsmodell",
"textModel": "Tekstmodell",
- "textTokenizer": "Tekst symbolbygger"
+ "textTokenizer": "Tekst-tokeniserer"
},
"context": "Frigate laster ned de nødvendige vektorrepresentasjonsmodellene for å støtte funksjonen for semantisk søk. Dette kan ta flere minutter, avhengig av hastigheten på nettverksforbindelsen din.",
"tips": {
@@ -65,7 +65,7 @@
"millisecondsToOffset": "Millisekunder å forskyve annoteringsdata. Standard: 0",
"tips": "TIPS: Tenk deg et hendelsesklipp med en person som går fra venstre til høyre. Hvis den omsluttende boksen i hendelsestidslinjen konsekvent er til venstre for personen, bør verdien reduseres. Tilsvarende, hvis en person går fra venstre til høyre og den omsluttende boksen konsekvent er foran personen, bør verdien økes.",
"toast": {
- "success": "Annoteringsforskyvning for {{camera}} er lagret i konfigurasjonsfilen. Start Frigate på nytt for å bruke endringene dine."
+ "success": "Annoteringsforskyvning for {{camera}} er lagret i konfigurasjonsfilen. Start Frigate på nytt for å aktivere endringene dine."
}
}
},
@@ -87,26 +87,30 @@
},
"toast": {
"success": {
- "updatedSublabel": "Under-merkelapp oppdatert med suksess.",
+ "updatedSublabel": "Underetikett ble oppdatert.",
"updatedLPR": "Vellykket oppdatering av kjennemerke.",
- "regenerate": "En ny beskrivelse har blitt anmodet fra {{provider}}. Avhengig av hastigheten til leverandøren din, kan den nye beskrivelsen ta litt tid å regenerere."
+ "regenerate": "En ny beskrivelse har blitt anmodet fra {{provider}}. Avhengig av hastigheten til leverandøren din, kan den nye beskrivelsen ta litt tid å regenerere.",
+ "audioTranscription": "Lydtranskripsjon ble forespurt. Avhengig av ytelsen på din Frigate server kan transkripsjonen ta noe tid å fullføre.",
+ "updatedAttributes": "Attributter ble oppdatert."
},
"error": {
"regenerate": "Feil ved anrop til {{provider}} for en ny beskrivelse: {{errorMessage}}",
"updatedLPRFailed": "Oppdatering av kjennemerke feilet: {{errorMessage}}",
- "updatedSublabelFailed": "Feil ved oppdatering av under-merkelapp: {{errorMessage}}"
+ "updatedSublabelFailed": "Feil ved oppdatering av underetikett: {{errorMessage}}",
+ "audioTranscription": "Forespørsel om lydtranskripsjon feilet: {{errorMessage}}",
+ "updatedAttributesFailed": "Kunne ikke oppdatere attributter: {{errorMessage}}"
}
},
"desc": "Detaljer for inspeksjonselement",
"tips": {
"mismatch_one": "{{count}} utilgjengelig objekt ble oppdaget og inkludert i dette inspeksjonselementet. Disse objektene kvalifiserte ikke som et varsel eller deteksjon, eller har allerede blitt ryddet opp/slettet.",
"mismatch_other": "{{count}} utilgjengelige objekter ble oppdaget og inkludert i dette inspeksjonselementet. Disse objektene kvalifiserte ikke som et varsel eller deteksjon, eller har allerede blitt ryddet opp/slettet.",
- "hasMissingObjects": "Juster konfigurasjonen hvis du vil at Frigate skal lagre sporede objekter for følgende merkelapper: {{objects}}"
+ "hasMissingObjects": "Juster konfigurasjonen hvis du vil at Frigate skal lagre sporede objekter for følgende etiketter: {{objects}}"
}
},
"topScore": {
- "info": "Den høyeste poengsummen er den høyeste medianverdi for det sporede objektet, så denne kan avvike fra poengsummen som vises på miniatyrbildet for søkeresultatet.",
- "label": "Høyeste poengsum"
+ "info": "Toppscoren er den høyeste medianverdien for det sporede objektet, så denne kan avvike fra scoren som vises på miniatyrbildet i søkeresultatet.",
+ "label": "Toppscore"
},
"estimatedSpeed": "Estimert hastighet",
"objects": "Objekter",
@@ -124,10 +128,10 @@
},
"regenerateFromThumbnails": "Regenerer fra miniatyrbilder",
"tips": {
- "descriptionSaved": "Beskrivelse lagret med suksess",
+ "descriptionSaved": "Beskrivelsen ble lagret",
"saveDescriptionFailed": "Feil ved lagring av beskrivelse: {{errorMessage}}"
},
- "label": "Merkelapp",
+ "label": "Etikett",
"editLPR": {
"title": "Rediger kjennemerke",
"descNoLabel": "Skriv inn et nytt kjennemerke for dette sporede objekt",
@@ -138,14 +142,25 @@
"zones": "Soner",
"timestamp": "Tidsstempel",
"expandRegenerationMenu": "Utvid regenereringsmenyen",
- "regenerateFromSnapshot": "Regenerer fra øyeblikksbilde",
+ "regenerateFromSnapshot": "Regenerer fra stillbilde",
"editSubLabel": {
- "title": "Rediger under-merkelapp",
- "desc": "Angi en ny under-merkelapp for denne {{label}}",
- "descNoLabel": "Angi en ny under-merkelapp for dette sporede objektet"
+ "title": "Rediger underetikett",
+ "desc": "Angi en ny underetikett for \"{{label}}\"",
+ "descNoLabel": "Angi en ny underetikett for dette sporede objektet"
},
"snapshotScore": {
- "label": "Øyeblikksbilde poengsum"
+ "label": "Stillbilde score"
+ },
+ "score": {
+ "label": "Score"
+ },
+ "editAttributes": {
+ "title": "Rediger attributter",
+ "desc": "Velg klassifiseringsattributter for denne {{label}}"
+ },
+ "attributes": "Klassifiseringsattributter",
+ "title": {
+ "label": "Tittel"
}
},
"itemMenu": {
@@ -158,8 +173,8 @@
"label": "Last ned video"
},
"downloadSnapshot": {
- "label": "Last ned øyeblikksbilde",
- "aria": "Last ned øyeblikksbilde"
+ "label": "Last ned stillbilde",
+ "aria": "Last ned stillbilde"
},
"viewObjectLifecycle": {
"label": "Vis objektets livssyklus",
@@ -175,33 +190,114 @@
"submitToPlus": {
"label": "Send til Frigate+",
"aria": "Send til Frigate Plus"
+ },
+ "addTrigger": {
+ "label": "Legg til utløser",
+ "aria": "Legg til en utløser for dette sporede objektet"
+ },
+ "audioTranscription": {
+ "label": "Transkriber",
+ "aria": "Forespør lydtranskripsjon"
+ },
+ "showObjectDetails": {
+ "label": "Vis objektets sti"
+ },
+ "hideObjectDetails": {
+ "label": "Skjul objektets sti"
+ },
+ "viewTrackingDetails": {
+ "label": "Vis sporingsdetaljer",
+ "aria": "Vis sporingsdetaljene"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Last ned rent stillbilde",
+ "aria": "Last ned stillbilde uten markeringer"
}
},
"searchResult": {
"deleteTrackedObject": {
"toast": {
"error": "Feil ved sletting av sporet objekt: {{errorMessage}}",
- "success": "Sporet objekt ble slettet med suksess."
+ "success": "Sporet objekt ble slettet."
}
},
- "tooltip": "Samsvarer {{type}} til {{confidence}}%"
+ "tooltip": "Samsvarer {{type}} til {{confidence}}%",
+ "previousTrackedObject": "Forrige sporede objekt",
+ "nextTrackedObject": "Neste sporede objekt"
},
"trackedObjectDetails": "Detaljer om sporet objekt",
"type": {
"details": "detaljer",
- "snapshot": "øyeblikksbilde",
+ "snapshot": "stillbilde",
"video": "video",
- "object_lifecycle": "objektets livssyklus"
+ "object_lifecycle": "objektets livssyklus",
+ "thumbnail": "miniatyrbilde",
+ "tracking_details": "sporingsdetaljer"
},
"dialog": {
"confirmDelete": {
"title": "Bekreft sletting",
- "desc": "Sletting av dette sporede objektet fjerner øyeblikksbildet, eventuelle lagrede vektorrepresentasjoner og alle tilknyttede livssykloppføringer for objektet. Opptak av dette sporede objektet i Historikk-visningen vil IKKE bli slettet.Stier
Linjer og sirkler vil indikere viktige punkter som det sporede objektet har beveget seg gjennom i løpet av sin livssyklus.
" } }, "users": { @@ -429,7 +495,7 @@ "desc": "Administrer brukerprofiler for denne Frigate-instansen." }, "addUser": "Legg til bruker", - "updatePassword": "Oppdater passord", + "updatePassword": "Nullstill passord", "toast": { "success": { "deleteUser": "Bruker {{user}} ble slettet", @@ -466,7 +532,16 @@ "strong": "Sterkt" }, "match": "Passordene samsvarer", - "notMatch": "Passordene samsvarer ikke" + "notMatch": "Passordene samsvarer ikke", + "show": "Vis passord", + "hide": "Skjul passord", + "requirements": { + "title": "Passordkrav:", + "length": "Minst 12 tegn", + "uppercase": "Minst en stor bokstav", + "digit": "Minst ett tall", + "special": "Minst ett spesialtegn (!@#$%^&*(),.?\":{}|<>)" + } }, "newPassword": { "title": "Nytt passord", @@ -476,7 +551,11 @@ } }, "usernameIsRequired": "Brukernavn er påkrevd", - "passwordIsRequired": "Passord er påkrevd" + "passwordIsRequired": "Passord er påkrevd", + "currentPassword": { + "title": "Nåværende passord", + "placeholder": "Skriv inn nåværende passord" + } }, "changeRole": { "desc": "Oppdater tillatelser for {{username}}", @@ -486,7 +565,8 @@ "admin": "Administrator", "adminDesc": "Full tilgang til alle funksjoner.", "viewer": "Visningsbruker", - "viewerDesc": "Begrenset til kun Direkte-dashbord, Inspiser, Utforsk og Eksporter." + "viewerDesc": "Begrenset til kun Direkte-dashbord, Inspiser, Utforsk og Eksporter.", + "customDesc": "Tilpasset rolle med spesifikk kameratilgang." }, "select": "Velg en rolle" }, @@ -506,7 +586,12 @@ "setPassword": "Angi passord", "desc": "Opprett et sterkt passord for å sikre denne kontoen.", "cannotBeEmpty": "Passordet kan ikke være tomt", - "doNotMatch": "Passordene samsvarer ikke" + "doNotMatch": "Passordene samsvarer ikke", + "currentPasswordRequired": "Nåværende passord er påkrevd", + "incorrectCurrentPassword": "Nåværende passord er feil", + "passwordVerificationFailed": "Kunne ikke verifisere passord", + "multiDeviceWarning": "Andre enheter du er logget inn på vil kreve ny innlogging innen {{refresh_time}}.", + "multiDeviceAdmin": "Du kan også tvinge alle brukere til å logge inn på nytt ved å endre JWT (JSON Web Token)-nøkkelen." } }, "table": { @@ -514,7 +599,7 @@ "actions": "Handlinger", "role": "Rolle", "changeRole": "Endre brukerrolle", - "password": "Passord", + "password": "Nullstill passord", "deleteUser": "Slett bruker", "noUsers": "Ingen brukere funnet." } @@ -602,18 +687,18 @@ }, "title": "Frigate+ Innstillinger", "snapshotConfig": { - "title": "Konfigurasjon av øyeblikksbilde", - "desc": "Innsending til Frigate+ krever at både øyeblikksbilder ogclean_copy-øyeblikksbilder er aktivert i konfigurasjonen din.",
+ "title": "Konfigurasjon av stillbilde",
+ "desc": "Innsending til Frigate+ krever at både stillbilder og clean_copy-stillbilder er aktivert i konfigurasjonen din.",
"documentation": "Se dokumentasjonen",
"table": {
"camera": "Kamera",
- "snapshots": "Øyeblikksbilder",
- "cleanCopySnapshots": "clean_copy-øyeblikksbilder"
+ "snapshots": "Stillbilder",
+ "cleanCopySnapshots": "clean_copy-stillbilder"
},
- "cleanCopyWarning": "Noen kameraer har øyeblikksbilder aktivert, men ren kopi er deaktivert. Du må aktivere clean_copy i øyeblikksbilde-konfigurasjonen for å kunne sende bilder fra disse kameraene til Frigate+."
+ "cleanCopyWarning": "Noen kameraer har stillbilder aktivert, men ren kopi er deaktivert. Du må aktivere clean_copy i stillbilde-konfigurasjonen for å kunne sende bilder fra disse kameraene til Frigate+."
},
"toast": {
- "success": "Frigate+ innstillingene er lagret. Start Frigate på nytt for å bruke endringene.",
+ "success": "Frigate+ innstillingene er lagret. Start Frigate på nytt for å aktivere endringene.",
"error": "Kunne ikke lagre konfigurasjonsendringer: {{errorMessage}}"
},
"restart_required": "Omstart påkrevd (Frigate+ modell endret)",
@@ -622,12 +707,12 @@
"enrichments": {
"title": "Innstillinger for utvidelser",
"licensePlateRecognition": {
- "desc": "Frigate kan gjenkjenne kjennemerker på kjøretøy og automatisk legge til de oppdagede tegnene i feltet \"recognized_license_plate\", eller et kjent navn som en under-merkelapp på objekter av typen bil. Et vanlig brukstilfelle kan være å lese kjennemerker på biler som kjører inn i en innkjørsel eller biler som passerer på en gate.",
+ "desc": "Frigate kan gjenkjenne kjennemerker på kjøretøy og automatisk legge til de oppdagede tegnene i feltet \"recognized_license_plate\", eller et kjent navn som en underetikett på objekter av typen bil. Et vanlig brukstilfelle kan være å lese kjennemerker på biler som kjører inn i en innkjørsel eller biler som passerer på en gate.",
"title": "Kjennemerke gjenkjenning",
"readTheDocumentation": "Se dokumentasjonen"
},
"birdClassification": {
- "desc": "Fugleklassifisering identifiserer kjente fugler ved hjelp av en kvantisert TensorFlow-modell. Når en fugl gjenkjennes, vil det vanlige navnet legges til som en under-merkelapp. Denne informasjonen vises i brukergrensesnittet, filtre, samt i meldingsvarsler.",
+ "desc": "Fugleklassifisering identifiserer kjente fugler ved hjelp av en kvantisert TensorFlow-modell. Når en fugl gjenkjennes, vil det vanlige navnet legges til som en underetikett. Denne informasjonen vises i brukergrensesnittet, filtre, samt i meldingsvarsler.",
"title": "Klassifisering av fugler"
},
"semanticSearch": {
@@ -671,14 +756,555 @@
}
},
"title": "Ansiktsgjenkjenning",
- "desc": "Ansiktsgjenkjenning gjør det mulig å tildele navn til personer, og når ansiktet deres gjenkjennes, vil Frigate tildele personens navn som en under-merkelapp. Denne informasjonen vises i brukergrensesnittet, filtre, samt i meldingsvarsler.",
+ "desc": "Ansiktsgjenkjenning gjør det mulig å tildele navn til personer, og når ansiktet deres gjenkjennes, vil Frigate tildele personens navn som en underetikett. Denne informasjonen vises i brukergrensesnittet, filtre, samt i meldingsvarsler.",
"readTheDocumentation": "Se dokumentasjonen"
},
"unsavedChanges": "Ulagrede endringer i innstillinger for utvidelser",
"restart_required": "Omstart påkrevd (Innstillinger for utvidelser er endret)",
"toast": {
- "success": "Innstillinger for utvidelser har blitt lagret. Start Frigate på nytt for å bruke endringene.",
+ "success": "Innstillinger for utvidelser har blitt lagret. Start Frigate på nytt for å aktivere endringene.",
"error": "Kunne ikke lagre konfigurasjonsendringer: {{errorMessage}}"
}
+ },
+ "triggers": {
+ "documentTitle": "Utløsere",
+ "management": {
+ "title": "Utløser",
+ "desc": "Administrer utløsere for {{camera}}. Bruk miniatyrbilde-type for å utløse på lignende miniatyrbilder som det sporede objektet du har valgt, og beskrivelsestype for å utløse på lignende beskrivelser basert på teksten du spesifiserer."
+ },
+ "addTrigger": "Legg til utløser",
+ "table": {
+ "name": "Navn",
+ "type": "Type",
+ "content": "Innhold",
+ "threshold": "Terskel",
+ "actions": "Handlinger",
+ "noTriggers": "Ingen utløsere er konfigurert for dette kameraet.",
+ "edit": "Rediger",
+ "deleteTrigger": "Slett utløser",
+ "lastTriggered": "Sist utløst"
+ },
+ "type": {
+ "thumbnail": "Miniatyrbilde",
+ "description": "Beskrivelse"
+ },
+ "actions": {
+ "alert": "Marker som varsel",
+ "notification": "Send meldingsvarsel",
+ "sub_label": "Legg til underetikett",
+ "attribute": "Legg til attributt"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "Opprett utløser",
+ "desc": "Opprett en utløser for kamera {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Rediger utløser",
+ "desc": "Rediger innstillingene for utløser på kamera {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Slett utløser",
+ "desc": "Er du sikker på at du vil slette utløseren {{triggerName}}? Denne handlingen kan ikke angres."
+ },
+ "form": {
+ "name": {
+ "title": "Navn",
+ "placeholder": "Navngi denne utløseren",
+ "error": {
+ "minLength": "Feltet må være minst 2 tegn langt.",
+ "invalidCharacters": "Feltet kan bare inneholde bokstaver, tall, understreker og bindestreker.",
+ "alreadyExists": "En utløser med dette navnet finnes allerede for dette kameraet."
+ },
+ "description": "Skriv inn et unikt navn eller beskrivelse for å identifisere denne utløseren"
+ },
+ "enabled": {
+ "description": "Aktiver eller deaktiver denne utløseren"
+ },
+ "type": {
+ "title": "Type",
+ "placeholder": "Velg utløsertype",
+ "description": "Utløs når en lignende sporet objektbeskrivelse blir detektert",
+ "thumbnail": "Utløs når et lignende sporet miniatyrbilde blir detektert"
+ },
+ "content": {
+ "title": "Innhold",
+ "imagePlaceholder": "Velg et miniatyrbilde",
+ "textPlaceholder": "Skriv inn tekstinnhold",
+ "imageDesc": "Kun de siste 100 miniatyrbildene vises. Hvis du ikke finner ønsket miniatyrbilde, kan du se gjennom tidligere objekter i Utforsk og opprette en utløser fra menyen der.",
+ "textDesc": "Skriv inn tekst for å utløse denne handlingen når en lignende beskrivelse av et sporet objekt oppdages.",
+ "error": {
+ "required": "Innhold er påkrevd."
+ }
+ },
+ "threshold": {
+ "title": "Terskel",
+ "error": {
+ "min": "Terskelverdien må minst være 0",
+ "max": "Terskelverdien kan maksimum være 1"
+ },
+ "desc": "Angi likhetsgrensen for denne utløseren. En høyere grense betyr at et høyere samsvar kreves for å utløse hendelsen."
+ },
+ "actions": {
+ "title": "Handlinger",
+ "desc": "Som standard sender Frigate en MQTT-melding for alle utløsere. Underetiketter legger til navnet på utløseren i objektetiketten. Attributter er søkbare metadata som lagres separat i objektets sporingsmetadata.",
+ "error": {
+ "min": "Minst én handling må velges."
+ }
+ },
+ "friendly_name": {
+ "description": "Et valgfritt brukervennlig navn eller beskrivende tekst for denne utløseren.",
+ "title": "Brukervennlig navn",
+ "placeholder": "Navngi eller beskriv denne utløseren"
+ }
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Utløseren {{name}} ble opprettet.",
+ "updateTrigger": "Utløseren {{name}} ble oppdatert.",
+ "deleteTrigger": "Utløseren {{name}} ble slettet."
+ },
+ "error": {
+ "createTriggerFailed": "Kunne ikke opprette utløser: {{errorMessage}}",
+ "updateTriggerFailed": "Kunne ikke oppdatere utløser: {{errorMessage}}",
+ "deleteTriggerFailed": "Kunne ikke slette utløser: {{errorMessage}}"
+ }
+ },
+ "semanticSearch": {
+ "title": "Semantisk søk er deaktivert",
+ "desc": "Semantisk søk må aktiveres for å bruke utløsere."
+ },
+ "wizard": {
+ "title": "Opprett utløser",
+ "step1": {
+ "description": "Konfigurer grunnleggende innstillinger for utløseren."
+ },
+ "step2": {
+ "description": "Sett opp innholdet som skal utløse denne handlingen."
+ },
+ "step3": {
+ "description": "Konfigurer terskelen og handlingene for denne utløseren."
+ },
+ "steps": {
+ "nameAndType": "Navn og type",
+ "configureData": "Konfigurer data",
+ "thresholdAndActions": "Terskel og handlinger"
+ }
+ }
+ },
+ "roles": {
+ "management": {
+ "title": "Administrasjon av visningsrolle",
+ "desc": "Administrer tilpassede visningsroller og deres kameratilgangstillatelser for denne Frigate-instansen."
+ },
+ "addRole": "Legg til rolle",
+ "table": {
+ "role": "Rolle",
+ "cameras": "Kameraer",
+ "actions": "Handlinger",
+ "noRoles": "Ingen tilpassede roller funnet.",
+ "editCameras": "Rediger kameraer",
+ "deleteRole": "Slett rolle"
+ },
+ "toast": {
+ "success": {
+ "createRole": "Rollen {{role}} ble opprettet",
+ "updateCameras": "Kameraer oppdatert for rollen {{role}}",
+ "deleteRole": "Rollen {{role}} ble slettet",
+ "userRolesUpdated_one": "{{count}} bruker tildelt denne rollen er oppdatert til \"visningsbruker\", som har tilgang til alle kameraer.",
+ "userRolesUpdated_other": "{{count}} brukere tildelt denne rollen er oppdatert til \"visningsbruker\", som har tilgang til alle kameraer."
+ },
+ "error": {
+ "createRoleFailed": "Kunne ikke opprette rolle: {{errorMessage}}",
+ "updateCamerasFailed": "Kunne ikke oppdatere kameraer: {{errorMessage}}",
+ "deleteRoleFailed": "Kunne ikke slette rolle: {{errorMessage}}",
+ "userUpdateFailed": "Kunne ikke oppdatere brukerroller: {{errorMessage}}"
+ }
+ },
+ "dialog": {
+ "createRole": {
+ "title": "Opprett ny rolle",
+ "desc": "Legg til en ny rolle og angi tillatelser for kameratilgang."
+ },
+ "editCameras": {
+ "desc": "Oppdater kameratilgang for rollen {{role}}.",
+ "title": "Rediger kameraer for rolle"
+ },
+ "deleteRole": {
+ "title": "Slett rolle",
+ "desc": "Denne handlingen kan ikke angres. Dette vil permanent slette rollen og tildele alle brukere med denne rollen til «visningsbruker»-rollen, som gir tilgang til alle kameraer.",
+ "warn": "Er du sikker på at du vil slette {{role}}?",
+ "deleting": "Sletter..."
+ },
+ "form": {
+ "role": {
+ "title": "Rollenavn",
+ "placeholder": "Skriv inn rollenavn",
+ "desc": "Kun bokstaver, tall, punktum og understreker er tillatt.",
+ "roleIsRequired": "Rollenavn er påkrevd",
+ "roleOnlyInclude": "Rollenavn kan kun inneholde bokstaver, tall, . eller _",
+ "roleExists": "En rolle med dette navnet finnes allerede."
+ },
+ "cameras": {
+ "title": "Kameraer",
+ "desc": "Velg hvilke kameraer denne rollen skal ha tilgang til. Minst ett kamera må velges.",
+ "required": "Minst ett kamera må velges."
+ }
+ }
+ }
+ },
+ "cameraWizard": {
+ "title": "Legg til kamera",
+ "description": "Følg trinnene nedenfor for å legge til et nytt kamera i din Frigate-installasjon.",
+ "steps": {
+ "nameAndConnection": "Navn og tilkobling",
+ "streamConfiguration": "Strømkonfigurasjon",
+ "validationAndTesting": "Validering og testing",
+ "probeOrSnapshot": "Sjekk eller stillbilde"
+ },
+ "save": {
+ "success": "Lagret nytt kamera {{cameraName}}.",
+ "failure": "Feil ved lagring av {{cameraName}}."
+ },
+ "testResultLabels": {
+ "resolution": "Oppløsning",
+ "video": "Video",
+ "audio": "Lyd",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Vennligst oppgi en gyldig strøm-URL",
+ "testFailed": "Strømmetest feilet: {{error}}"
+ },
+ "step1": {
+ "description": "Skriv inn kameradetaljene dine og velg å sjekke kameraet eller manuelt velg produsent.",
+ "cameraName": "Kameranavn",
+ "cameraNamePlaceholder": "f.eks. front_dor eller Hageoversikt",
+ "host": "Vert/IP-adresse",
+ "port": "Port",
+ "username": "Brukernavn",
+ "usernamePlaceholder": "Valgfritt",
+ "password": "Passord",
+ "passwordPlaceholder": "Valgfritt",
+ "selectTransport": "Velg transportprotokoll",
+ "cameraBrand": "Kameramerke",
+ "selectBrand": "Velg kameramerke for URL-mal",
+ "customUrl": "Egendefinert strømme-URL",
+ "brandInformation": "Merkevare-informasjon",
+ "brandUrlFormat": "For kameraer med RTSP URL-format som: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://brukernavn:passord@vert:port/sti",
+ "testConnection": "Test tilkobling",
+ "testSuccess": "Tilkoblingstesten var vellykket!",
+ "testFailed": "Tilkoblingstesten feilet. Vennligst sjekk inntastingen din og prøv igjen.",
+ "streamDetails": "Strømdetaljer",
+ "warnings": {
+ "noSnapshot": "Kunne ikke hente et øyeblikksbilde fra den konfigurerte strømmen."
+ },
+ "errors": {
+ "brandOrCustomUrlRequired": "Enten velg et kameramerke med vert/IP eller velg 'Annet' med en egendefinert URL",
+ "nameRequired": "Kameranavn er påkrevd",
+ "nameLength": "Kameranavnet må være 64 tegn eller mindre",
+ "invalidCharacters": "Kameranavnet inneholder ugyldige tegn",
+ "nameExists": "Kameranavnet finnes allerede",
+ "brands": {
+ "reolink-rtsp": "Reolink RTSP anbefales ikke. Aktiver HTTP i kameraets fastvare-innstillinger og start kameraveiviseren på nytt."
+ },
+ "customUrlRtspRequired": "Egendefinerte URL-er må begynne med \"rtsp://\". Manuell konfigurering kreves for kamerastrømmer som ikke bruker RTSP."
+ },
+ "docs": {
+ "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras"
+ },
+ "testing": {
+ "probingMetadata": "Henter kamerametadata…",
+ "fetchingSnapshot": "Henter øyeblikksbilde for kamera..."
+ },
+ "connectionSettings": "Tilkoblingsinnstillinger",
+ "detectionMethod": "Metode for strømdeteksjon",
+ "onvifPort": "ONVIF-port",
+ "probeMode": "Sjekk kamera",
+ "manualMode": "Manuelt valg",
+ "detectionMethodDescription": "Sjekk kameraet med ONVIF (hvis støttet) for å finne kameraets strømme-URL-er, eller velg kameramerke manuelt for å bruke forhåndsdefinerte URL-er. For å skrive inn en egendefinert RTSP URL, velg manuell metode og velg \"Annet\".",
+ "onvifPortDescription": "For kameraer som støtter ONVIF, er dette vanligvis 80 eller 8080.",
+ "useDigestAuth": "Bruk digest-autentisering",
+ "useDigestAuthDescription": "Bruk HTTP digest-autentisering for ONVIF. Noen kameraer kan kreve et dedikert ONVIF brukernavn/passord i stedet for standard administrator-bruker."
+ },
+ "step2": {
+ "description": "Sjekk kameraet for tilgjengelige strømmer eller konfigurer manuelle innstillinger basert på valgt deteksjonsmetode.",
+ "streamsTitle": "Kamerastrømmer",
+ "addStream": "Legg til strøm",
+ "addAnotherStream": "Legg til en annen strøm",
+ "streamTitle": "Strøm {{number}}",
+ "streamUrl": "Strøm-URL",
+ "streamUrlPlaceholder": "rtsp://brukernavn:passord@vert:port/sti",
+ "url": "URL",
+ "resolution": "Oppløsning",
+ "selectResolution": "Velg oppløsning",
+ "quality": "Kvalitet",
+ "selectQuality": "Velg kvalitet",
+ "roles": "Roller",
+ "roleLabels": {
+ "detect": "Objektdeteksjon",
+ "record": "Opptak",
+ "audio": "Lyd"
+ },
+ "testStream": "Test tilkobling",
+ "testSuccess": "Tilkoblingstest vellykket!",
+ "testFailed": "Tilkoblingstest feilet. Vennligst sjekk inndataene dine og prøv igjen.",
+ "testFailedTitle": "Test feilet",
+ "connected": "Tilkoblet",
+ "notConnected": "Ikke tilkoblet",
+ "featuresTitle": "Funksjoner",
+ "go2rtc": "Reduser tilkoblinger til kameraet",
+ "detectRoleWarning": "Minst én strøm må ha rollen «deteksjon» for å fortsette.",
+ "rolesPopover": {
+ "title": "Strømroller",
+ "detect": "Hovedstrøm for objektdeteksjon.",
+ "record": "Lagrer segmenter av videostrømmen basert på konfigurasjonsinnstillinger.",
+ "audio": "Strøm for lydbasert deteksjon."
+ },
+ "featuresPopover": {
+ "title": "Strømfunksjoner",
+ "description": "Bruk go2rtc-restrømming for å redusere antall tilkoblinger til kameraet ditt."
+ },
+ "streamDetails": "Strømdetaljer",
+ "probing": "Test kamera...",
+ "retry": "Prøv på nytt",
+ "testing": {
+ "probingMetadata": "Sjekker metadata for kamera...",
+ "fetchingSnapshot": "Henter stillbilde fra kamera..."
+ },
+ "probeFailed": "Kunne ikke å sjekke kamera: {{error}}",
+ "probingDevice": "Tester enhet...",
+ "probeSuccessful": "Sjekk vellykket",
+ "probeError": "Sjekk feilet",
+ "probeNoSuccess": "Sjekk mislyktes",
+ "deviceInfo": "Enhetsinformasjon",
+ "manufacturer": "Produsent",
+ "model": "Modell",
+ "firmware": "Fastvare",
+ "profiles": "Profiler",
+ "ptzSupport": "PTZ-støtte",
+ "autotrackingSupport": "Autosporing-støtte",
+ "presets": "Forhåndsinnstillinger",
+ "rtspCandidates": "RTSP-kandidater",
+ "rtspCandidatesDescription": "Følgende RTSP URL-er ble funnet ved sjekk av kameraet. Test tilkoblingen for å se strømmetadata.",
+ "noRtspCandidates": "Ingen RTSP URL-er ble funnet fra kameraet. Det kan hende at påloggingsinformasjonen din er feil, eller at kameraet ikke støtter ONVIF eller metoden som brukes for å hente RTSP URL-er. Gå tilbake og skriv inn RTSP URL-en manuelt.",
+ "candidateStreamTitle": "Kandidat {{number}}",
+ "useCandidate": "Bruk",
+ "uriCopy": "Kopier",
+ "uriCopied": "URI kopiert til utklippstavlen",
+ "testConnection": "Test tilkobling",
+ "toggleUriView": "Klikk for å vise/skjule full URI",
+ "errors": {
+ "hostRequired": "Vert/IP-adresse er påkrevd"
+ }
+ },
+ "step3": {
+ "description": "Konfigurer strømroller og legg til flere strømmer for kameraet ditt.",
+ "validationTitle": "Strømvalidering",
+ "connectAllStreams": "Koble til alle strømmer",
+ "reconnectionSuccess": "Gjenoppkobling vellykket.",
+ "reconnectionPartial": "Noen strømmer kunne ikke gjenoppkobles.",
+ "streamUnavailable": "Forhåndsvisning av strøm utilgjengelig",
+ "reload": "Last inn på nytt",
+ "connecting": "Kobler til...",
+ "streamTitle": "Strøm {{number}}",
+ "valid": "Gyldig",
+ "failed": "Feilet",
+ "notTested": "Ikke testet",
+ "connectStream": "Koble til",
+ "connectingStream": "Kobler til",
+ "disconnectStream": "Koble fra",
+ "estimatedBandwidth": "Estimert båndbredde",
+ "roles": "Roller",
+ "none": "Ingen",
+ "error": "Feil",
+ "streamValidated": "Strøm {{number}} ble validert",
+ "streamValidationFailed": "Validering av strøm {{number}} feilet",
+ "saveAndApply": "Lagre nytt kamera",
+ "saveError": "Ugyldig konfigurasjon. Vennligst sjekk innstillingene dine.",
+ "issues": {
+ "title": "Strømvalidering",
+ "videoCodecGood": "Video-kodek er {{codec}}.",
+ "audioCodecGood": "Lyd-kodek er {{codec}}.",
+ "noAudioWarning": "Ingen lyd oppdaget for denne strømmen, opptak vil ikke ha lyd.",
+ "audioCodecRecordError": "AAC lyd-kodek er påkrevd for å støtte lyd i opptak.",
+ "audioCodecRequired": "En lydstrøm er påkrevd for å støtte lyddeteksjon.",
+ "restreamingWarning": "Å redusere tilkoblinger til kameraet for opptaksstrømmen kan øke CPU-bruken noe.",
+ "dahua": {
+ "substreamWarning": "Substrøm 1 er låst til lav oppløsning. Mange Dahua / Amcrest / EmpireTech-kameraer støtter flere substrømmer som må aktiveres i kameraets innstillinger. Det anbefales å sjekke og benytte disse strømmene hvis de er tilgjengelige."
+ },
+ "hikvision": {
+ "substreamWarning": "Substrøm 1 er låst til lav oppløsning. Mange Hikvision-kameraer støtter flere substrømmer som må aktiveres i kameraets innstillinger. Det anbefales å sjekke og benytte disse strømmene hvis de er tilgjengelige."
+ },
+ "resolutionHigh": "En oppløsning på {{resolution}} kan føre til økt ressursbruk.",
+ "resolutionLow": "En oppløsning på {{resolution}} kan være for lav for pålitelig deteksjon av små objekter."
+ },
+ "ffmpegModuleDescription": "Hvis strømmen ikke lastes inn etter flere forsøk, kan du prøve å aktivere dette. Når det er aktivert, vil Frigate bruke ffmpeg-modulen sammen med go2rtc. Dette kan gi bedre kompatibilitet med enkelte kamerastrømmer.",
+ "ffmpegModule": "Bruk kompatibilitetsmodus for strøm",
+ "streamsTitle": "Kamerastrømmer",
+ "addStream": "Legg til strøm",
+ "addAnotherStream": "Legg til en annen strøm",
+ "streamUrl": "Strøm-URL",
+ "streamUrlPlaceholder": "rtsp://brukernavn:passord@vert:port/sti",
+ "selectStream": "Velg en strøm",
+ "searchCandidates": "Søk blant kandidater...",
+ "noStreamFound": "Ingen strøm funnet",
+ "url": "URL",
+ "resolution": "Oppløsning",
+ "selectResolution": "Velg oppløsning",
+ "quality": "Kvalitet",
+ "selectQuality": "Velg kvalitet",
+ "roleLabels": {
+ "detect": "Objektdeteksjon",
+ "record": "Opptak",
+ "audio": "Lyd"
+ },
+ "testStream": "Test tilkobling",
+ "testSuccess": "Strømmetest vellykket!",
+ "testFailed": "Strømmetest feilet",
+ "testFailedTitle": "Test feilet",
+ "connected": "Tilkoblet",
+ "notConnected": "Ikke tilkoblet",
+ "featuresTitle": "Funksjoner",
+ "go2rtc": "Reduser antall tilkoblinger til kamera",
+ "detectRoleWarning": "Minst én strøm må ha \"deteksjon\"-rollen for å fortsette.",
+ "rolesPopover": {
+ "title": "Strømroller",
+ "detect": "Hovedstrøm for objektdeteksjon.",
+ "record": "Lagrer segmenter av videostrømmen basert på konfigurasjonsinnstillinger.",
+ "audio": "Strøm for lydbasert deteksjon."
+ },
+ "featuresPopover": {
+ "title": "Strømfunksjoner",
+ "description": "Bruk go2rtc-restrømming for å redusere antall tilkoblinger til kameraet."
+ }
+ },
+ "step4": {
+ "description": "Endelig validering og analyse før du lagrer det nye kameraet. Koble til hver strøm før du lagrer.",
+ "validationTitle": "Strømvalidering",
+ "connectAllStreams": "Koble til alle strømmer",
+ "reconnectionSuccess": "Tilkobling vellykket.",
+ "reconnectionPartial": "Noen strømmer kunne ikke koble til på nytt.",
+ "streamUnavailable": "Forhåndsvisning av strøm utilgjengelig",
+ "reload": "Last på nytt",
+ "connecting": "Kobler til...",
+ "streamTitle": "Strøm {{number}}",
+ "valid": "Gyldig",
+ "failed": "Feilet",
+ "notTested": "Ikke testet",
+ "connectStream": "Koble til",
+ "connectingStream": "Kobler til",
+ "disconnectStream": "Koble fra",
+ "estimatedBandwidth": "Estimert båndbredde",
+ "roles": "Roller",
+ "ffmpegModule": "Bruk kompatibilitetsmodus for strøm",
+ "ffmpegModuleDescription": "Hvis strømmen ikke lastes etter flere forsøk, prøv å aktivere dette. Når aktivert, vil Frigate bruke ffmpeg-modulen med go2rtc. Dette kan gi bedre kompatibilitet med noen kamerastrømmer.",
+ "none": "Ingen",
+ "error": "Feil",
+ "streamValidated": "Strøm {{number}} validert",
+ "streamValidationFailed": "Validering av strøm {{number}} feilet",
+ "saveAndApply": "Lagre nytt kamera",
+ "saveError": "Ugyldig konfigurasjon. Vennligst sjekk innstillingene dine.",
+ "issues": {
+ "title": "Strømvalidering",
+ "videoCodecGood": "Videokodek er {{codec}}.",
+ "audioCodecGood": "Lydkodek er {{codec}}.",
+ "resolutionHigh": "En oppløsning på {{resolution}} kan føre til økt ressursbruk.",
+ "resolutionLow": "En oppløsning på {{resolution}} kan være for lav for pålitelig deteksjon av små objekter.",
+ "noAudioWarning": "Ingen lyd oppdaget for denne strømmen, opptak vil ikke ha lyd.",
+ "audioCodecRecordError": "AAC-lydkodeken kreves for å støtte lyd i opptak.",
+ "audioCodecRequired": "En lydstrøm kreves for å støtte lyddeteksjon.",
+ "restreamingWarning": "Å redusere tilkoblinger til kameraet for opptaksstrømmen kan øke CPU-bruken noe.",
+ "brands": {
+ "reolink-rtsp": "Reolink RTSP anbefales ikke. Aktiver HTTP i kameraets fastvareinnstillinger og start veiviseren på nytt.",
+ "reolink-http": "Reolink HTTP-strømmer bør bruke FFmpeg for bedre kompatibilitet. Aktiver 'Bruk kompatibilitetsmodus for strøm' for denne strømmen."
+ },
+ "dahua": {
+ "substreamWarning": "Substrøm 1 er låst til lav oppløsning. Mange Dahua / Amcrest / EmpireTech-kameraer støtter flere substrømmer som må aktiveres i kameraets innstillinger. Det anbefales å sjekke og benytte disse strømmene hvis de er tilgjengelige."
+ },
+ "hikvision": {
+ "substreamWarning": "Substrøm 1 er låst til lav oppløsning. Mange Hikvision-kameraer støtter flere substrømmer som må aktiveres i kameraets innstillinger. Det anbefales å sjekke og benytte disse strømmene hvis de er tilgjengelige."
+ }
+ }
+ }
+ },
+ "cameraManagement": {
+ "title": "Administrer kameraer",
+ "addCamera": "Legg til nytt kamera",
+ "editCamera": "Rediger kamera:",
+ "selectCamera": "Velg et kamera",
+ "backToSettings": "Tilbake til kamerainnstillinger",
+ "streams": {
+ "title": "Aktiver / Deaktiver kameraer",
+ "desc": "Midlertidig deaktiver et kamera til Frigate startes på nytt. Deaktivering av et kamera stopper Frigates behandling av dette kameraets strømmer fullstendig. Deteksjon, opptak og feilsøking vil være utilgjengelig.Paden
Lijnen en cirkels geven belangrijke punten aan waar het gevolgde object zich tijdens zijn levensduur heeft verplaatst.
" + }, + "openCameraWebUI": "Open de webinterface van {{camera}}", + "audio": { + "title": "Audio", + "noAudioDetections": "Geen audiodetecties", + "score": "score", + "currentRMS": "Huidige RMS", + "currentdbFS": "Huidige dbFS" + } }, "users": { "title": "Gebruikers", @@ -429,7 +495,7 @@ "title": "Gebruikersbeheer" }, "addUser": "Gebruiker toevoegen", - "updatePassword": "Wachtwoord bijwerken", + "updatePassword": "Wachtwoord opnieuw instellen", "toast": { "success": { "createUser": "Gebruiker {{user}} succesvol aangemaakt", @@ -449,7 +515,7 @@ "role": "Rol", "noUsers": "Geen gebruikers gevonden.", "changeRole": "Gebruikersrol wijzigen", - "password": "Wachtwoord", + "password": "Wachtwoord opnieuw instellen", "deleteUser": "Verwijder gebruiker", "username": "Gebruikersnaam" }, @@ -475,7 +541,16 @@ "placeholder": "Wachtwoord bevestigen" }, "placeholder": "Wachtwoord invoeren", - "notMatch": "Wachtwoorden komen niet overeen" + "notMatch": "Wachtwoorden komen niet overeen", + "show": "Wachtwoord weergeven", + "hide": "Wachtwoord verbergen", + "requirements": { + "title": "Wachtwoordvereisten:", + "length": "Minimaal 8 tekens", + "uppercase": "Minimaal één hoofdletter", + "digit": "Minimaal één cijfer", + "special": "Minimaal één speciaal teken (!@#$%^&*(),.?\":{}|<>)" + } }, "newPassword": { "title": "Nieuw wachtwoord", @@ -485,7 +560,11 @@ } }, "usernameIsRequired": "Gebruikersnaam is vereist", - "passwordIsRequired": "Wachtwoord is vereist" + "passwordIsRequired": "Wachtwoord is vereist", + "currentPassword": { + "title": "Huidig wachtwoord", + "placeholder": "Voer uw huidige wachtwoord in" + } }, "createUser": { "title": "Nieuwe gebruiker aanmaken", @@ -505,8 +584,9 @@ "intro": "Selecteer een gepaste rol voor deze gebruiker:", "admin": "Beheerder", "adminDesc": "Volledige toegang tot alle functies.", - "viewer": "Gebruiker", - "viewerDesc": "Alleen toegang tot Live-dashboards, Beoordelen, Verkennen en Exports." + "viewer": "Kijker", + "viewerDesc": "Alleen toegang tot Live-dashboards, Beoordelen, Verkennen en Exports.", + "customDesc": "Aangepaste rol met specifieke cameratoegang." }, "select": "Selecteer een rol" }, @@ -515,7 +595,12 @@ "updatePassword": "Wachtwoord bijwerken voor {{username}}", "desc": "Maak een sterk wachtwoord aan om dit account te beveiligen.", "cannotBeEmpty": "Het wachtwoord kan niet leeg zijn", - "doNotMatch": "Wachtwoorden komen niet overeen" + "doNotMatch": "Wachtwoorden komen niet overeen", + "currentPasswordRequired": "Huidig wachtwoord is vereist", + "incorrectCurrentPassword": "Het huidige wachtwoord is onjuist", + "passwordVerificationFailed": "Wachtwoord kan niet worden geverifieerd", + "multiDeviceWarning": "Op alle andere apparaten waarop u bent ingelogd, moet u binnen {{refresh_time}} opnieuw inloggen.", + "multiDeviceAdmin": "Je kunt ook alle gebruikers forceren zich onmiddellijk opnieuw te authenticeren door je JWT-geheim te roteren." } } }, @@ -680,5 +765,546 @@ "success": "Verrijkingsinstellingen zijn opgeslagen. Start Frigate opnieuw op om je wijzigingen toe te passen.", "error": "Configuratiewijzigingen konden niet worden opgeslagen: {{errorMessage}}" } + }, + "triggers": { + "documentTitle": "Triggers", + "management": { + "title": "Triggers", + "desc": "Beheer triggers voor {{camera}}. Gebruik een thumbnail om te triggeren op vergelijkbare thumbnails van het door jou gevolgde object, of gebruik een objectbeschrijving om te triggeren op vergelijkbare beschrijvingen van de door jou opgegeven tekst." + }, + "addTrigger": "Trigger toevoegen", + "table": { + "name": "Naam", + "type": "Type", + "content": "Inhoud", + "threshold": "Drempel", + "actions": "Acties", + "noTriggers": "Er zijn geen triggers geconfigureerd voor deze camera.", + "edit": "Bewerken", + "deleteTrigger": "Trigger verwijderen", + "lastTriggered": "Laatst geactiveerd" + }, + "type": { + "thumbnail": "Thumbnail", + "description": "Beschrijving" + }, + "actions": { + "alert": "Markeren als waarschuwing", + "notification": "Melding verzenden", + "sub_label": "Sublabel toevoegen", + "attribute": "Attribuut toevoegen" + }, + "dialog": { + "createTrigger": { + "title": "Trigger aanmaken", + "desc": "Maak een trigger voor camera {{camera}}" + }, + "editTrigger": { + "title": "Trigger bewerken", + "desc": "Wijzig de instellingen voor de trigger op camera {{camera}}" + }, + "deleteTrigger": { + "title": "Trigger verwijderen", + "desc": "Weet u zeker dat u de trigger {{triggerName}} wilt verwijderen? Deze actie kan niet ongedaan worden gemaakt." + }, + "form": { + "name": { + "title": "Naam", + "placeholder": "Geef deze trigger een naam", + "error": { + "minLength": "Het veld moet minimaal 2 tekens lang zijn.", + "invalidCharacters": "Dit veld mag alleen letters, cijfers, onderstrepingstekens en koppeltekens bevatten.", + "alreadyExists": "Er bestaat al een trigger met deze naam voor deze camera." + }, + "description": "Voer een unieke naam of beschrijving in om deze trigger te identificeren" + }, + "enabled": { + "description": "Deze trigger in- of uitschakelen" + }, + "type": { + "title": "Type", + "placeholder": "Selecteer het type trigger", + "description": "Activeer wanneer een vergelijkbare beschrijving van een gevolgd object wordt gedetecteerd", + "thumbnail": "Activeer wanneer een vergelijkbare thumbnail van een gevolgd object wordt gedetecteerd" + }, + "content": { + "title": "Inhoud", + "imagePlaceholder": "Selecteer een thumbnail", + "textPlaceholder": "Tekst invoeren", + "imageDesc": "Alleen de meest recente 100 thumbnails worden weergegeven. Als je de gewenste thumbnail niet kunt vinden, bekijk dan eerdere objecten in Verkennen en stel daar een trigger in via het menu.", + "textDesc": "Voer tekst in om deze actie te activeren wanneer een vergelijkbare beschrijving van een gevolgd object wordt gedetecteerd.", + "error": { + "required": "Inhoud is vereist." + } + }, + "threshold": { + "title": "Drempel", + "error": { + "min": "De drempelwaarde moet minimaal 0 zijn", + "max": "De drempelwaarde mag maximaal 1 zijn" + }, + "desc": "Stel de vergelijkingsdrempel in voor deze trigger. Een hogere drempel betekent dat er een nauwere overeenkomst vereist is om de trigger te activeren." + }, + "actions": { + "title": "Acties", + "desc": "Standaard stuurt Frigate een MQTT-bericht voor alle triggers. Sublabels voegen de triggernaam toe aan het objectlabel. Attributen zijn doorzoekbare metadata die afzonderlijk worden opgeslagen in de metadata van het gevolgde object.", + "error": { + "min": "Er moet ten minste één actie worden geselecteerd." + } + }, + "friendly_name": { + "title": "Gebruiksvriendelijke naam", + "placeholder": "Geef een naam of beschrijf deze trigger", + "description": "Een optionele gebruiksvriendelijke naam of beschrijvende tekst voor deze trigger." + } + } + }, + "toast": { + "success": { + "createTrigger": "Trigger {{name}} is succesvol aangemaakt.", + "updateTrigger": "Trigger {{name}} is succesvol bijgewerkt.", + "deleteTrigger": "Trigger {{name}} succesvol verwijderd." + }, + "error": { + "createTriggerFailed": "Trigger kan niet worden gemaakt: {{errorMessage}}", + "updateTriggerFailed": "Trigger kan niet worden bijgewerkt: {{errorMessage}}", + "deleteTriggerFailed": "Trigger kan niet worden verwijderd: {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "Semantisch zoeken is uitgeschakeld", + "desc": "Semantisch zoeken moet ingeschakeld zijn om triggers te kunnen gebruiken." + }, + "wizard": { + "title": "Trigger maken", + "step1": { + "description": "Configureer de basisinstellingen voor uw trigger." + }, + "step2": { + "description": "Stel de inhoud in die deze trigger activeert." + }, + "step3": { + "description": "Configureer de drempelwaarde en acties voor deze trigger." + }, + "steps": { + "nameAndType": "Naam en type", + "configureData": "Gegevens configureren", + "thresholdAndActions": "Drempel en acties" + } + } + }, + "roles": { + "management": { + "title": "Beheer van kijkersrollen", + "desc": "Beheer aangepaste kijkersrollen en hun camera-toegangsrechten voor deze Frigate-instantie." + }, + "addRole": "Rol toevoegen", + "table": { + "role": "Rol", + "cameras": "Camera's", + "actions": "Acties", + "noRoles": "Er zijn geen aangepaste rollen gevonden.", + "editCameras": "Camera's bewerken", + "deleteRole": "Rol verwijderen" + }, + "toast": { + "success": { + "createRole": "Rol {{role}} succesvol aangemaakt", + "updateCameras": "Camera's bijgewerkt voor rol {{role}}", + "deleteRole": "Rol {{role}} succesvol verwijderd", + "userRolesUpdated_one": "{{count}} gebruiker die aan deze rol was toegewezen, is bijgewerkt naar de rol ‘kijker’, die toegang heeft tot alle camera’s.", + "userRolesUpdated_other": "{{count}} gebruikers die aan deze rol waren toegewezen, zijn bijgewerkt naar de rol ‘kijker’, die toegang heeft tot alle camera’s." + }, + "error": { + "createRoleFailed": "Kan rol niet aanmaken: {{errorMessage}}", + "updateCamerasFailed": "Het is niet gelukt om de camera's bij te werken: {{errorMessage}}", + "deleteRoleFailed": "Kan rol niet verwijderen: {{errorMessage}}", + "userUpdateFailed": "Het bijwerken van gebruikersrollen is mislukt: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Nieuwe rol maken", + "desc": "Voeg een nieuwe rol toe en specificeer de camera-toegangsrechten." + }, + "editCameras": { + "title": "Camera’s voor rol bewerken", + "desc": "Werk de camera-toegang bij voor de rol {{role}}." + }, + "deleteRole": { + "title": "Rol verwijderen", + "desc": "Deze actie kan niet ongedaan worden gemaakt. De rol wordt permanent verwijderd en alle gebruikers met deze rol worden toegewezen aan de rol ‘kijker’, die toegang geeft tot alle camera’s.", + "warn": "Weet u zeker dat u {{role}} wilt verwijderen?", + "deleting": "Verwijderen..." + }, + "form": { + "role": { + "title": "Rolnaam", + "placeholder": "Voer rolnaam in", + "desc": "Alleen letters, cijfers, punten en underscores zijn toegestaan.", + "roleIsRequired": "Rolnaam is vereist", + "roleOnlyInclude": "De rolnaam mag alleen letters, cijfers, . of _ bevatten", + "roleExists": "Er bestaat al een rol met deze naam." + }, + "cameras": { + "title": "Camera's", + "desc": "Selecteer de camera's waartoe deze rol toegang heeft. Er is minimaal één camera vereist.", + "required": "Er moet minimaal één camera worden geselecteerd." + } + } + } + }, + "cameraWizard": { + "title": "Camera toevoegen", + "description": "Volg de onderstaande stappen om een nieuwe camera toe te voegen aan uw Frigate-installatie.", + "steps": { + "nameAndConnection": "Naam & Verbinding", + "streamConfiguration": "Streamconfiguratie", + "validationAndTesting": "Validatie & testen", + "probeOrSnapshot": "Test of Snapshot" + }, + "save": { + "success": "Nieuwe camera {{cameraName}} succesvol opgeslagen.", + "failure": "Fout bij het opslaan van {{cameraName}}." + }, + "testResultLabels": { + "resolution": "Resolutie", + "video": "Video", + "audio": "Audio", + "fps": "FPS" + }, + "commonErrors": { + "noUrl": "Geef een geldige stream-URL op", + "testFailed": "Streamtest mislukt: {{error}}" + }, + "step1": { + "description": "Voer de gegevens van uw camera in en kies ervoor om de camera te scannen of selecteer handmatig het merk.", + "cameraName": "Cameranaam", + "cameraNamePlaceholder": "bijv. voordeur of achtertuin camera", + "host": "Host/IP-adres", + "port": "Port", + "username": "Gebruikersnaam", + "usernamePlaceholder": "Optioneel", + "password": "Wachtwoord", + "passwordPlaceholder": "Optioneel", + "selectTransport": "Selecteer transportprotocol", + "cameraBrand": "Cameramerk", + "selectBrand": "Selecteer cameramerk voor URL-sjabloon", + "customUrl": "Aangepaste stream-URL", + "brandInformation": "Merkinformatie", + "brandUrlFormat": "Voor camera's met het RTSP URL-formaat als: {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://gebruikersnaam:wachtwoord@host:poort/pad", + "testConnection": "Testverbinding", + "testSuccess": "Verbindingstest succesvol!", + "testFailed": "Verbindingstest mislukt. Controleer uw invoer en probeer het opnieuw.", + "streamDetails": "Streamdetails", + "warnings": { + "noSnapshot": "Er kan geen snapshot worden opgehaald uit de geconfigureerde stream." + }, + "errors": { + "brandOrCustomUrlRequired": "Selecteer een cameramerk met host/IP of kies 'Overig' voor een aangepaste URL", + "nameRequired": "Cameranaam is vereist", + "nameLength": "De cameranaam mag maximaal 64 tekens lang zijn", + "invalidCharacters": "Cameranaam bevat ongeldige tekens", + "nameExists": "Cameranaam bestaat al", + "brands": { + "reolink-rtsp": "Reolink RTSP wordt niet aanbevolen. Schakel HTTP in via de firmware-instellingen van de camera en start de wizard opnieuw." + }, + "customUrlRtspRequired": "Aangepaste URL’s moeten beginnen met “rtsp://”. Handmatige configuratie is vereist voor camerastreams die geen RTSP gebruiken." + }, + "docs": { + "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras" + }, + "testing": { + "probingMetadata": "Camerametadata wordt onderzocht...", + "fetchingSnapshot": "Camerasnapshot ophalen..." + }, + "connectionSettings": "Verbindingsinstellingen", + "detectionMethod": "Stream-detectiemethode", + "onvifPort": "ONVIF-poort", + "probeMode": "Camera testen", + "manualMode": "Handmatige selectie", + "detectionMethodDescription": "Test de camera met ONVIF (indien ondersteund) om de stream-URL’s van de camera te vinden, of selecteer handmatig het cameramerk om vooraf gedefinieerde URL’s te gebruiken. Om een aangepaste RTSP-URL in te voeren, kies de handmatige methode en selecteer “Anders”.", + "onvifPortDescription": "Voor camera's die ONVIF ondersteunen, is dit meestal 80 of 8080.", + "useDigestAuth": "Gebruik digest-authenticatie", + "useDigestAuthDescription": "Gebruik HTTP-digestauthenticatie voor ONVIF. Sommige camera’s vereisen mogelijk een aparte ONVIF-gebruikersnaam en -wachtwoord in plaats van de standaard ‘admin’ gebruiker." + }, + "step2": { + "description": "Controleer de camera op beschikbare streams of configureer handmatige instellingen op basis van de door u geselecteerde detectiemethode.", + "streamsTitle": "Camerastreams", + "addStream": "Stream toevoegen", + "addAnotherStream": "Voeg een extra stream toe", + "streamTitle": "Stream {{number}}", + "streamUrl": "Stream-URL", + "streamUrlPlaceholder": "rtsp://gebruikersnaam:wachtwoord@host:poort/pad", + "url": "URL", + "resolution": "Resolutie", + "selectResolution": "Selecteer resolutie", + "quality": "Kwaliteit", + "selectQuality": "Selecteer kwaliteit", + "roles": "Functie", + "roleLabels": { + "detect": "Objectdetectie", + "record": "Opname", + "audio": "Audio" + }, + "testStream": "Testverbinding", + "testSuccess": "Verbindingstest succesvol!", + "testFailed": "Verbindingstest mislukt. Controleer uw invoer en probeer het opnieuw.", + "testFailedTitle": "Test mislukt", + "connected": "Aangesloten", + "notConnected": "Niet verbonden", + "featuresTitle": "Functies", + "go2rtc": "Verminder verbindingen met de camera", + "detectRoleWarning": "Er moet minimaal één stream de rol 'detecteren' hebben om door te kunnen gaan.", + "rolesPopover": { + "title": "Streamrollen", + "detect": "Hoofdfeed voor objectdetectie.", + "record": "Slaat segmenten van de videofeed op op basis van de configuratie-instellingen.", + "audio": "Feed voor op audio gebaseerde detectie." + }, + "featuresPopover": { + "title": "Streamfuncties", + "description": "Gebruik go2rtc-herstreaming om het aantal verbindingen met je camera te verminderen." + }, + "streamDetails": "Streamdetails", + "probing": "Camera wordt getest...", + "retry": "Opnieuw proberen", + "testing": { + "probingMetadata": "Camera-metadata onderzoeken...", + "fetchingSnapshot": "Camerasnapshot ophalen..." + }, + "probeFailed": "Het testen van de camera is mislukt: {{error}}", + "probingDevice": "Onderzoekapparaat...", + "probeSuccessful": "Test succesvol", + "probeError": "Testfout", + "probeNoSuccess": "Test mislukt", + "deviceInfo": "Apparaatinformatie", + "manufacturer": "Fabrikant", + "model": "Model", + "firmware": "Firmware", + "profiles": "Profielen", + "ptzSupport": "PTZ-ondersteuning", + "autotrackingSupport": "Ondersteuning voor automatische tracking", + "presets": "Standaardinstellingen", + "rtspCandidates": "RTSP-kandidaten", + "rtspCandidatesDescription": "De volgende RTSP-URL's zijn gevonden door de camera te scannen. Test de verbinding om de metagegevens van de stream te bekijken.", + "noRtspCandidates": "Er zijn geen RTSP-URL’s gevonden van de camera. Je inloggegevens zijn mogelijk onjuist, of de camera ondersteunt ONVIF of de gebruikte methode voor het ophalen van RTSP-URL’s niet. Ga terug en voer de RTSP-URL handmatig in.", + "candidateStreamTitle": "Kandidaat {{number}}", + "useCandidate": "Gebruik", + "uriCopy": "Kopiëren", + "uriCopied": "URI gekopieerd naar klembord", + "testConnection": "Testverbinding", + "toggleUriView": "Klik om te schakelen tussen volledige URI-weergave", + "errors": { + "hostRequired": "Host/IP-adres is vereist" + } + }, + "step3": { + "description": "Configureer streamrollen en voeg extra streams toe voor uw camera.", + "validationTitle": "Streamvalidatie", + "connectAllStreams": "Verbind alle streams", + "reconnectionSuccess": "Opnieuw verbinden gelukt.", + "reconnectionPartial": "Bij sommige streams kon de verbinding niet worden hersteld.", + "streamUnavailable": "Streamvoorbeeld niet beschikbaar", + "reload": "Herladen", + "connecting": "Verbinden...", + "streamTitle": "Stream {{number}}", + "valid": "Geldig", + "failed": "Mislukt", + "notTested": "Niet getest", + "connectStream": "Verbinden", + "connectingStream": "Verbinden", + "disconnectStream": "Verbreek verbinding", + "estimatedBandwidth": "Geschatte bandbreedte", + "roles": "Functie", + "none": "Niets", + "error": "Fout", + "streamValidated": "Stream {{number}} is succesvol gevalideerd", + "streamValidationFailed": "Stream {{number}} validatie mislukt", + "saveAndApply": "Nieuwe camera opslaan", + "saveError": "Ongeldige configuratie, Controleer uw instellingen.", + "issues": { + "title": "Streamvalidatie", + "videoCodecGood": "Videocodec is {{codec}}.", + "audioCodecGood": "Audiocodec is {{codec}}.", + "noAudioWarning": "Geen audio gedetecteerd voor deze stream, opnames bevatten geen audio.", + "audioCodecRecordError": "De AAC-audiocodec is vereist om audio in opnames te ondersteunen.", + "audioCodecRequired": "Ter ondersteuning van audiodetectie is een audiostream vereist.", + "restreamingWarning": "Als u het aantal verbindingen met de camera voor de opnamestream vermindert, kan het CPU-gebruik iets toenemen.", + "dahua": { + "substreamWarning": "Substream 1 is beperkt tot een lage resolutie. Veel Dahua / Amcrest / EmpireTech camera’s ondersteunen extra substreams die in de instellingen van de camera ingeschakeld moeten worden. Het wordt aanbevolen deze streams te controleren en te gebruiken indien beschikbaar." + }, + "hikvision": { + "substreamWarning": "Substream 1 is beperkt tot een lage resolutie. Veel Hikvision-camera’s ondersteunen extra substreams die in de instellingen van de camera ingeschakeld moeten worden. Het wordt aanbevolen deze streams te controleren en te gebruiken indien beschikbaar." + }, + "resolutionHigh": "Een resolutie van {{resolution}} kan leiden tot een verhoogd gebruik van systeembronnen.", + "resolutionLow": "Een resolutie van {{resolution}} kan te laag zijn voor betrouwbare detectie van kleine objecten." + }, + "ffmpegModule": "Gebruik stream-compatibiliteitsmodus", + "ffmpegModuleDescription": "Als de stream na meerdere pogingen niet wordt geladen, probeer dit dan in te schakelen. Wanneer deze optie is ingeschakeld, gebruikt Frigate de ffmpeg-module samen met go2rtc. Dit kan zorgen voor een betere compatibiliteit met sommige camerastreams.", + "streamsTitle": "Camerastreams", + "addStream": "Stream toevoegen", + "addAnotherStream": "Voeg een extra stream toe", + "streamUrl": "Stream-URL", + "streamUrlPlaceholder": "rtsp://gebruikersnaam:wachtwoord@host:poort/pad", + "selectStream": "Selecteer een stream", + "searchCandidates": "Zoek kandidaten...", + "noStreamFound": "Geen stream gevonden", + "url": "URL", + "resolution": "Resolutie", + "selectResolution": "Selecteer resolutie", + "quality": "Kwaliteit", + "selectQuality": "Selecteer kwaliteit", + "roleLabels": { + "detect": "Objectdetectie", + "record": "Opname", + "audio": "Audio" + }, + "testStream": "Testverbinding", + "testSuccess": "Streamtest succesvol!", + "testFailed": "Streamtest mislukt", + "testFailedTitle": "Test mislukt", + "connected": "Aangesloten", + "notConnected": "Niet verbonden", + "featuresTitle": "Functies", + "go2rtc": "Verminder verbindingen met de camera", + "detectRoleWarning": "Er moet minimaal één stream de rol 'detecteren' hebben om door te kunnen gaan.", + "rolesPopover": { + "title": "Streamrollen", + "detect": "Hoofdstream voor objectdetectie.", + "record": "Slaat segmenten van de videostream op op basis van de configuratie-instellingen.", + "audio": "Stream voor op audio gebaseerde detectie." + }, + "featuresPopover": { + "title": "Streamfuncties", + "description": "Gebruik go2rtc-herstreaming om het aantal verbindingen met je camera te verminderen." + } + }, + "step4": { + "description": "Laatste controle en analyse voordat je je nieuwe camera opslaat. Verbind elke stream voordat je opslaat.", + "validationTitle": "Streamvalidatie", + "connectAllStreams": "Verbind alle streams", + "reconnectionSuccess": "Opnieuw verbinden gelukt.", + "reconnectionPartial": "Bij sommige streams kon de verbinding niet worden hersteld.", + "streamUnavailable": "Streamvoorbeeld niet beschikbaar", + "reload": "Herladen", + "connecting": "Verbinden...", + "streamTitle": "Stream {{number}}", + "valid": "Geldig", + "failed": "Mislukt", + "notTested": "Niet getest", + "connectStream": "Verbinden", + "connectingStream": "Verbinden", + "disconnectStream": "Verbreek verbinding", + "estimatedBandwidth": "Geschatte bandbreedte", + "roles": "Rollen", + "ffmpegModule": "Gebruik stream-compatibiliteitsmodus", + "ffmpegModuleDescription": "Als de stream na meerdere pogingen niet wordt geladen, probeer dit dan in te schakelen. Wanneer deze optie is ingeschakeld, gebruikt Frigate de ffmpeg-module samen met go2rtc. Dit kan zorgen voor een betere compatibiliteit met sommige camerastreams.", + "none": "Geen", + "error": "Fout", + "streamValidated": "Stream {{number}} is succesvol gevalideerd", + "streamValidationFailed": "Stream {{number}} validatie mislukt", + "saveAndApply": "Nieuwe camera opslaan", + "saveError": "Ongeldige configuratie, Controleer uw instellingen.", + "issues": { + "title": "Streamvalidatie", + "videoCodecGood": "Videocodec is {{codec}}.", + "audioCodecGood": "Audiocodec is {{codec}}.", + "resolutionHigh": "Een resolutie van {{resolution}} kan leiden tot een verhoogd gebruik van systeembronnen.", + "resolutionLow": "Een resolutie van {{resolution}} kan te laag zijn voor betrouwbare detectie van kleine objecten.", + "noAudioWarning": "Geen audio gedetecteerd voor deze stream, opnames bevatten geen audio.", + "audioCodecRecordError": "De AAC-audiocodec is vereist om audio in opnames te ondersteunen.", + "audioCodecRequired": "Ter ondersteuning van audiodetectie is een audiostream vereist.", + "restreamingWarning": "Als u het aantal verbindingen met de camera voor de opnamestream vermindert, kan het CPU-gebruik iets toenemen.", + "brands": { + "reolink-rtsp": "Reolink RTSP wordt niet aanbevolen. Schakel HTTP in via de firmware-instellingen van de camera en start de wizard opnieuw.", + "reolink-http": "Reolink HTTP-streams moeten FFmpeg gebruiken voor een betere compatibiliteit. Schakel ‘stream-compatibiliteitsmodus’ in voor deze stream." + }, + "dahua": { + "substreamWarning": "Substream 1 is beperkt tot een lage resolutie. Veel Dahua / Amcrest / EmpireTech camera’s ondersteunen extra substreams die in de instellingen van de camera ingeschakeld moeten worden. Het wordt aanbevolen deze streams te controleren en te gebruiken indien beschikbaar." + }, + "hikvision": { + "substreamWarning": "Substream 1 is beperkt tot een lage resolutie. Veel Hikvision-camera’s ondersteunen extra substreams die in de instellingen van de camera ingeschakeld moeten worden. Het wordt aanbevolen deze streams te controleren en te gebruiken indien beschikbaar." + } + } + } + }, + "cameraManagement": { + "title": "Camera’s beheren", + "addCamera": "Nieuwe camera toevoegen", + "editCamera": "Camera bewerken:", + "selectCamera": "Selecteer een camera", + "backToSettings": "Terug naar camera-instellingen", + "streams": { + "title": "Camera's in-/uitschakelen", + "desc": "Schakel een camera tijdelijk uit totdat Frigate opnieuw wordt gestart. Het uitschakelen van een camera stopt de verwerking van de streams van deze camera volledig door Frigate. Detectie, opname en foutopsporing zijn dan niet beschikbaar.Ścieżki
Linie i koła wskażą punkty znaczące po których poruszał się obiekt podczas śledzenia.
" } }, "motionDetectionTuner": { @@ -427,7 +492,7 @@ }, "users": { "addUser": "Dodaj Użytkownika", - "updatePassword": "Aktualizuj Hasło", + "updatePassword": "Resetuj Hasło", "toast": { "success": { "createUser": "Użytkownik {{user}} został utworzony pomyślnie", @@ -448,7 +513,7 @@ "role": "Rola", "noUsers": "Nie znaleziono użytkowników.", "changeRole": "Zmień rolę użytkownika", - "password": "Hasło", + "password": "Resetuj hasło", "deleteUser": "Usuń użytkownika" }, "dialog": { @@ -473,7 +538,16 @@ }, "title": "Hasło", "placeholder": "Wprowadź hasło", - "notMatch": "Hasła nie pasują" + "notMatch": "Hasła nie pasują", + "show": "Pokaż hasło", + "hide": "Ukryj hasło", + "requirements": { + "title": "Wymagania hasła:", + "length": "Co najmniej 12 znaków", + "uppercase": "Co najmniej jedna duża litera", + "digit": "Co najmniej jedna cyfra", + "special": "Co najmniej jeden znak specjalny (!@#$%^&*(),.?\":{}|<>)" + } }, "newPassword": { "placeholder": "Wprowadź nowe hasło", @@ -483,7 +557,11 @@ } }, "usernameIsRequired": "Nazwa użytkownika jest wymagana", - "passwordIsRequired": "Hasło jest wymagane" + "passwordIsRequired": "Hasło jest wymagane", + "currentPassword": { + "title": "Aktualne hasło", + "placeholder": "Wprowadź aktualne hasło" + } }, "changeRole": { "desc": "Aktualizuj uprawnienia dla {{username}}", @@ -492,7 +570,8 @@ "admin": "Admin", "adminDesc": "Pełny dostęp do wszystkich funkcjonalności.", "viewerDesc": "Ograniczony wyłącznie do pulpitów na żywo, przeglądania, eksploracji i eksportu.", - "viewer": "Przeglądający" + "viewer": "Przeglądający", + "customDesc": "Własna rola z dedykowanym dostępem do kamery." }, "title": "Zmień rolę użytkownika", "select": "Wybierz role" @@ -513,7 +592,12 @@ "setPassword": "Ustaw hasło", "desc": "Utwórz silne hasło, aby zabezpieczyć to konto.", "cannotBeEmpty": "Hasło nie może być puste", - "doNotMatch": "Hasła nie pasują do siebie" + "doNotMatch": "Hasła nie pasują do siebie", + "currentPasswordRequired": "Wymagane jest aktualne hasło", + "incorrectCurrentPassword": "Aktualne hasło jest nieprawidłowe", + "passwordVerificationFailed": "Nie udało się zweryfikować hasła", + "multiDeviceWarning": "Wszystkie inne urządzenia, na których jesteś zalogowany, będą wymagały ponownego zalogowania się w ciągu {{refresh_time}}.", + "multiDeviceAdmin": "Możesz również wymusić natychmiastowe ponowne uwierzytelnienie wszystkich użytkowników poprzez zmianę sekretu JWT." } }, "management": { @@ -640,7 +724,7 @@ } } }, - "title": "Ustawienia wzbogacania", + "title": "Ustawienia wzbogaceń", "unsavedChanges": "Niezapisane zmiany ustawień wzbogacania", "birdClassification": { "title": "Klasyfikacja ptaków", @@ -683,5 +767,460 @@ "success": "Ustawienia wzbogacania zostały zapisane. Uruchom ponownie Frigate, aby zastosować zmiany.", "error": "Nie udało się zapisać zmian konfiguracji: {{errorMessage}}" } + }, + "roles": { + "management": { + "title": "Zarządzanie rolami podglądu", + "desc": "Zarządzaj własnymi rolami podglądu i ich dostępem do kamer dla tej instancji Frigate." + }, + "addRole": "Dodaj rolę", + "table": { + "role": "Rola", + "cameras": "Kamery", + "actions": "Akcje", + "noRoles": "Brak własnych ról.", + "editCameras": "Edytuj kamery", + "deleteRole": "Usuń rolę" + }, + "toast": { + "success": { + "createRole": "Utworzono rolę {{role}}", + "updateCameras": "Zaktualizowano kamery dla roli {{role}}", + "deleteRole": "Rola {{role}} została usunięta", + "userRolesUpdated_one": "{{count}} użytkowników przypisanych do tej roli zostało zaktualizowanych do roli 'viewer', która ma dostęp do wszystkich kamer.", + "userRolesUpdated_few": "", + "userRolesUpdated_many": "" + }, + "error": { + "createRoleFailed": "Nie udało się utworzyć roli: {{errorMessage}}", + "updateCamerasFailed": "Nie udało się zaktualizować kamery: {{errorMessage}}", + "deleteRoleFailed": "Nie udało się usunąć roli: {{errorMessage}}", + "userUpdateFailed": "Nie udało się zaktualizować ról użytkownika: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Dodaj nową rolę", + "desc": "Dodaj nową rolę i określ prawa dostępu do kamer." + }, + "editCameras": { + "title": "Edytuj kamery roli", + "desc": "Aktualizuj dostęp do kamer dla roli {{role}}." + }, + "deleteRole": { + "title": "Usuń rolę", + "desc": "Ta akcja nie może zostać wycofana. To usunie rolę na stałe i przypisze jej użytkowników do roli 'viewer' która ma dostęp do wszystkich kamer.", + "warn": "Czy na pewno chcesz usunąć rolę {{role}}?", + "deleting": "Usuwanie..." + }, + "form": { + "role": { + "title": "Nazwa roli", + "placeholder": "Wprowadź nazwę roli", + "desc": "Tylko litery, liczby, kropki i podkreślenie są dozwolone.", + "roleIsRequired": "Nazwa roli jest wymagana", + "roleOnlyInclude": "Nazwa roli może zawierać litery, liczby, . albo _", + "roleExists": "Taka rola już istnieje." + }, + "cameras": { + "title": "Kamery", + "desc": "Wybierz do jakich kamer ta rola ma dostęp. Wymagana jest przynajmniej jedna kamera.", + "required": "Przynajmniej jedna kamera musi zostać wybrana." + } + } + } + }, + "triggers": { + "documentTitle": "Wyzwalacze", + "management": { + "title": "Wyzwalacze", + "desc": "Zarządzaj wyzwalaczami dla kamery {{camera}}. Użyj typu miniatury, aby aktywować miniatury podobne do wybranego śledzonego obiektu, i typu opisu, aby aktywować opisy podobne do określonego tekstu." + }, + "addTrigger": "Dodaj wyzwalacz", + "table": { + "name": "Nazwa", + "type": "Typ", + "content": "Zawartość", + "threshold": "Próg", + "actions": "Akcje", + "noTriggers": "Brak wyzwalaczy dla tej kamery.", + "edit": "Edytuj", + "deleteTrigger": "Usuń wyzwalacz", + "lastTriggered": "Ostatnio wyzwolony" + }, + "type": { + "thumbnail": "Miniaturka", + "description": "Opis" + }, + "actions": { + "alert": "Oznacz jako alarm", + "notification": "Wyślij powiadomienie", + "sub_label": "Dodaj podetykietę", + "attribute": "Dodaj atrybut" + }, + "dialog": { + "createTrigger": { + "title": "Utwórz wyzwalacz", + "desc": "Utwórz wyzwalacz dla kamery {{camera}}" + }, + "editTrigger": { + "title": "Edytuj wyzwalacz", + "desc": "Edytuj ustawienia wyzwalacza na kamerze {{camera}}" + }, + "deleteTrigger": { + "title": "Usuń wyzwalacz", + "desc": "Czy na pewno chcesz usunąć wyzwalacz {{triggerName}}? To działanie jest nieodwracalne." + }, + "form": { + "name": { + "title": "Nazwa", + "placeholder": "Wprowadź nazwę wyzwalacza", + "error": { + "minLength": "Pole musi mieć co najmniej 2 znaki.", + "invalidCharacters": "Pole może zawierać jedynie litery, liczby, podkreślenie i myślniki.", + "alreadyExists": "Wyzwalacz o tej nazwie istnieje już dla tej kamery." + }, + "description": "Wprowadź unikalną nazwę lub opis, aby zidentyfikować ten wyzwalacz" + }, + "enabled": { + "description": "Włącz lub wyłącz ten wyzwalacz" + }, + "type": { + "title": "Typ", + "placeholder": "Wybierz typ wyzwalacza", + "description": "Uruchom, gdy wykryty zostanie podobny opis śledzonego obiektu", + "thumbnail": "Uruchom, gdy wykryta zostanie podobna miniatura śledzonego obiektu" + }, + "content": { + "title": "Zawartość", + "imagePlaceholder": "Wybierz miniaturkę", + "textPlaceholder": "Wprowadź treść", + "imageDesc": "Wyświetlane jest tylko 100 najnowszych miniatur. Jeśli nie możesz znaleźć żądanej miniatury, przejrzyj wcześniejsze obiekty w sekcji Eksploruj i skonfiguruj wyzwalacz z menu w tym miejscu.", + "textDesc": "Wprowadź tekst, który spowoduje uruchomienie tej akcji po wykryciu podobnego opisu śledzonego obiektu.", + "error": { + "required": "Zawartość jest wymagana." + } + }, + "threshold": { + "title": "Próg", + "error": { + "min": "Próg musi wynosić co najmniej 0", + "max": "Próg nie może być większy niż 1" + }, + "desc": "Ustaw próg podobieństwa dla tego wyzwalacza. Wyższy próg oznacza, że do uruchomienia wyzwalacza wymagane jest większe dopasowanie." + }, + "actions": { + "title": "Akcje", + "desc": "Domyślnie Frigate wysyła komunikat MQTT dla wszystkich wyzwalaczy. Podetykiety dodają nazwę wyzwalacza do etykiety obiektu. Atrybuty to metadane, które można przeszukiwać, przechowywane oddzielnie w metadanych śledzonego obiektu.", + "error": { + "min": "Musisz wybrać co najmniej jedną akcję." + } + }, + "friendly_name": { + "title": "Przyjazna nazwa", + "placeholder": "Nazwij lub opisz ten trigger", + "description": "Opcjonalna przyjazna nazwa lub opis tego triggera." + } + } + }, + "toast": { + "success": { + "createTrigger": "Utworzono wyzwalacz {{name}}.", + "updateTrigger": "Zaktualizowano wyzwalacz {{name}}.", + "deleteTrigger": "Usunięto wyzwalacz {{name}}." + }, + "error": { + "createTriggerFailed": "Nie udało się utworzyć wyzwalacza: {{errorMessage}}", + "updateTriggerFailed": "Nie udało się zaktualizować wyzwalacza: {{errorMessage}}", + "deleteTriggerFailed": "Nie udało się usunąć wyzwalacza: {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "Wyszukiwanie semantyczne jest zablokowane", + "desc": "Wyszukiwanie semantyczne musi być włączone, aby korzystać z triggerów." + }, + "wizard": { + "title": "Utwórz wyzwalacz", + "step1": { + "description": "Skonfiguruj podstawowe ustawienia wyzwalacza." + }, + "step2": { + "description": "Skonfiguruj treść, która uruchomi tę akcję." + }, + "step3": { + "description": "Skonfiguruj próg i działania dla tego wyzwalacza." + }, + "steps": { + "nameAndType": "Nazwa i typ", + "configureData": "Skonfiguruj dane", + "thresholdAndActions": "Próg i akcje" + } + } + }, + "cameraWizard": { + "title": "Dodaj kamerę", + "steps": { + "streamConfiguration": "Konfiguracja strumienia", + "nameAndConnection": "Nazwa i połączenie", + "probeOrSnapshot": "Sonda lub migawka", + "validationAndTesting": "Walidacja i testowanie" + }, + "save": { + "success": "Zapisano ustawienia nowej kamery {{cameraName}}.", + "failure": "Błąd zapisu {{cameraName}}." + }, + "testResultLabels": { + "resolution": "Rozdzielczość", + "fps": "kl./s", + "video": "Wideo", + "audio": "Audio" + }, + "commonErrors": { + "noUrl": "Podaj poprawny adres URL", + "testFailed": "Negatywny wynik testu strumienia: {{error}}" + }, + "step1": { + "cameraName": "Nazwa kamery", + "cameraNamePlaceholder": "np. drzwi_frontowe lub Ogród", + "host": "Host/Adres IP", + "port": "Port", + "username": "Nazwa użytkownika", + "usernamePlaceholder": "Opcjonalne", + "password": "Hasło", + "passwordPlaceholder": "Opcjonalne", + "selectTransport": "Wybierz protokół warstwy transportowej", + "cameraBrand": "Marka Kamery", + "selectBrand": "Wybierz markę kamery aby dostosować wzór adresu URL", + "customUrl": "Niestandardowy adres URL strumienia", + "brandInformation": "Informacje o marce", + "brandUrlFormat": "Dla kamer z formatem RTSP, formatuj URL jako: {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://nazwa_użytkownika:hasło@host:port/scieżka", + "connectionSettings": "Ustawienia Połączenia", + "detectionMethod": "Metoda wykrywania strumienia", + "onvifPort": "Port ONVIF", + "manualMode": "Ręczny wybór", + "onvifPortDescription": "Dla kamer wspierających protokół ONVIF, port to zazwyczaj 80 lub 8080.", + "errors": { + "brandOrCustomUrlRequired": "Wybierz markę kamery oraz host/adres IP lub wybierz 'Inny' i podaj niestandardowy adres URL", + "nameRequired": "Wymagana nazwa kamery", + "nameLength": "Nazwa kamery musi mieć 64 lub mniej znaków", + "invalidCharacters": "Nazwa kamery zawiera niepoprawne znaki", + "nameExists": "Nazwa kamery jest już zajęta", + "customUrlRtspRequired": "Niestandardowe adresy URL muszą zaczynać się od \"rtsp://\". Ręczna konfiguracja wymagana jest dla strumieniów innych niż RTSP." + }, + "description": "Wprowadź szczegóły kamery i wybierz autodetekcję lub ręcznie wybierz firmę.", + "probeMode": "Wykryj kamerę", + "detectionMethodDescription": "Wykryj kamerę za pomocą ONVIF (jeśli wspierane) by znaleźć adresy strumieni lub wybierz ręcznie markę kamery by wybrać predefiniowane adresy. By wpisać własny adres strumienia RTSP użyj ręcznej metody i wybierz \"Inne\".", + "useDigestAuth": "Użyj przesyłania skrótu autentykacji", + "useDigestAuthDescription": "Użyj przesyłania skrótu logowania HTTP dla ONVIF. Niektóre kamery mogą wymagać dedykowanego użytkownika i hasła ONVIF zamiast standardowego konta admin." + }, + "step2": { + "testSuccess": "Test połączenia udany!", + "testFailed": "Test połączenia nieudany. Sprawdź adres źródła obrazu i spróbuj ponownie.", + "testFailedTitle": "Test Nieudany", + "streamDetails": "Szczegóły Strumienia", + "testing": { + "fetchingSnapshot": "Przygotowywanie migawki kamery...", + "probingMetadata": "Wykrywanie metadanych kamery..." + }, + "deviceInfo": "Informacje o urządzeniu", + "manufacturer": "Producent", + "model": "Model", + "firmware": "Firmware", + "profiles": "Profile", + "ptzSupport": "Wsparcie PTZ", + "autotrackingSupport": "Wsparcie auto-śledzenia", + "uriCopy": "Kopiuj", + "uriCopied": "Adres URL skopiowano do schowka", + "testConnection": "Przetestuj połączenie", + "errors": { + "hostRequired": "Wymagany jest Host/Adres IP" + }, + "description": "Wykryj dostępne strumienie kamery lub skonfiguruj ręcznie ustawienia na podstawie wybranej metody detekcji.", + "probing": "Wykrywanie kamery...", + "retry": "Ponów", + "probeFailed": "Błąd wykrywania kamery: {{error}}", + "probingDevice": "Wykrywanie urządzenia...", + "probeSuccessful": "Wykrywanie udane", + "probeError": "Błąd wykrywania", + "probeNoSuccess": "Niepowodzenie wykrywania", + "presets": "Ustawienia wstępne", + "rtspCandidates": "Kandydaci RTSP", + "rtspCandidatesDescription": "W wyniku sprawdzania kamery znaleziono następujące adresy URL RTSP. Przetestuj połączenie, aby wyświetlić metadane strumienia.", + "noRtspCandidates": "Nie znaleziono adresów URL RTSP z kamery. Twoje dane uwierzytelniające mogą być nieprawidłowe lub kamera może nie obsługiwać protokołu ONVIF lub metody używanej do pobierania adresów URL RTSP. Wróć i wprowadź adres URL RTSP ręcznie.", + "candidateStreamTitle": "Kandydat {{number}}", + "useCandidate": "Użyj", + "toggleUriView": "Kliknij, aby przełączyć widok pełnego adresu URI", + "connected": "Połączony", + "notConnected": "Niepołączony" + }, + "step3": { + "streamTitle": "Strumień numer: {{number}}", + "streamUrl": "URL strumienia", + "streamUrlPlaceholder": "rtsp://nazwa_użytkownika:hasło@host:port/scieżka", + "selectStream": "Wybierz strumień", + "noStreamFound": "Nie znaleziono żadnego strumienia", + "url": "adres URL", + "resolution": "Rozdzielczość", + "selectResolution": "Wybierz rozdzielczość", + "quality": "Jakość", + "selectQuality": "wybierz jakość", + "roles": "Role", + "roleLabels": { + "detect": "Wykrywanie obiektów", + "record": "Nagrywanie", + "audio": "Dźwięk" + }, + "testStream": "Przetestuj połączenie", + "testSuccess": "Test strumienia udany!", + "testFailed": "Test strumienia nieudany", + "testFailedTitle": "Test nieudany", + "connected": "Połączono", + "notConnected": "Nie połączono", + "featuresTitle": "Funkcje", + "go2rtc": "Ogranicz połączenia do kamery", + "detectRoleWarning": "Przynajmniej jeden strumień musi mieć rolę \"detect\".", + "rolesPopover": { + "title": "Role strumienia", + "detect": "Główny strumień służący do wykrywania obiektów.", + "record": "Zapisuje fragmenty strumienia wideo zgodnie z ustawieniami konfiguracyjnymi.", + "audio": "Kanał do wykrywania opartego na dźwięku." + }, + "featuresPopover": { + "title": "Funkcje strumienia", + "description": "Użyj funkcji ponownego przesyłania strumienia go2rtc, aby zmniejszyć liczbę połączeń z kamerą." + }, + "description": "Skonfiguruj role strumieni i dodaj dodatkowe strumienie dla swojej kamery.", + "streamsTitle": "Strumienie kamery", + "addStream": "Dodaj strumień", + "addAnotherStream": "Dodaj kolejny strumień", + "searchCandidates": "Szukaj kandydatów..." + }, + "step4": { + "description": "Końcowa walidacja i analiza przed zapisaniem ustawień nowej kamery. Połącz się z każdym strumieniem przed zapisaniem.", + "validationTitle": "Walidacja strumienia", + "reconnectionSuccess": "Ponowna próba połączenia udana.", + "streamUnavailable": "Podgląd strumienia niedostępny", + "connecting": "Łączenie...", + "streamTitle": "Strumień numer: {{number}}", + "valid": "Poprawny", + "connectingStream": "Łączenie", + "disconnectStream": "Rozłącz", + "estimatedBandwidth": "Przewidywana przepustowość", + "roles": "Role", + "ffmpegModuleDescription": "Jeżeli po kilku próbach strumień nadal nie ładuje się, uruchom ten tryb. Gdy włączony jest ten tryb Frigate będzie używać modułu ffmpeg z go2rtc. Może to zapewnić lepszą kompatybilność z niektórymi typami strumieniów.", + "none": "Brak", + "error": "Błąd", + "streamValidated": "Strumień numer: {{number}} przeszedł test pozytywnie", + "streamValidationFailed": "Strumień numer: {{number}} test nieudany", + "saveAndApply": "Zapisz nową kamerę", + "saveError": "Nieprawidłowa konfiguracja. Sprawdź ustawienia.", + "issues": { + "title": "Walidacja strumienia", + "audioCodecGood": "Kodek dźwięku to {{codec}}.", + "resolutionHigh": "Rozdzielczość {{resolution}} może spowodować większe zużycie zasobów.", + "resolutionLow": "Rozdzielczość {{resolution}} może okazać się za mała aby poprawnie wykrywać małe obiekty.", + "noAudioWarning": "Nie wykryto dźwięku dla tego strumienia, nagrania również nie będą zawierać dźwięku.", + "audioCodecRecordError": "Kodek AAC jest wymagany aby uwzględnić dźwięk w nagraniach.", + "audioCodecRequired": "Strumień audio jest wymagany aby umożliwić wykrywanie dźwięku.", + "restreamingWarning": "Ograniczenie ilości połączeń do strumienia nagrań może delikatnie zwiększyć użycie procesora.", + "brands": { + "reolink-rtsp": "Strumień RTSP dla kamer firmy Reolink nie jest rekomendowany. Uruchom strumień HTTP w oprogramowaniu kamery i uruchom kreator jeszcze raz.", + "reolink-http": "Strumienie HTTP Reolink powinny korzystać z FFmpeg w celu zapewnienia lepszej kompatybilności. Włącz opcję 'Użyj trybu kompatybilności strumienia' dla tego strumienia." + }, + "videoCodecGood": "Kodek wideo to {{codec}}.", + "dahua": { + "substreamWarning": "Podstrumień 1 jest zablokowany na niskiej rozdzielczości. Wiele kamer Dahua / Amcrest / EmpireTech obsługuje dodatkowe podstrumienie, które należy włączyć w ustawieniach kamery. Zaleca się sprawdzenie i wykorzystanie tych strumieni, jeśli są dostępne." + }, + "hikvision": { + "substreamWarning": "Podstrumień 1 jest zablokowany na niskiej rozdzielczości. Wiele kamer Hikvision obsługuje dodatkowe podstrumienie, które należy włączyć w ustawieniach kamery. Zaleca się sprawdzenie i wykorzystanie tych strumieni, jeśli są dostępne." + } + }, + "connectAllStreams": "Podłącz wszystkie strumienie", + "reconnectionPartial": "Niektóre strumienie nie zostały ponownie połączone.", + "reload": "Przeładuj", + "failed": "Nie powiodło się", + "notTested": "Nietestowane", + "connectStream": "Połącz", + "ffmpegModule": "Użyj trybu zgodności strumienia" + }, + "description": "Wykonaj poniższe kroki aby dodać nową kamerę do Frigate." + }, + "cameraManagement": { + "title": "Zarządzaj kamerami", + "addCamera": "Dodaj nową kamerę", + "editCamera": "Edytuj kamerę:", + "selectCamera": "Wybierz kamerę", + "backToSettings": "Powrót do ustawień kamery", + "streams": { + "title": "Włącz / Wyłącz kamery", + "desc": "Tymczasowo wyłącz kamerę do momentu ponownego uruchomienia Frigate. Wyłączenie kamery całkowicie zatrzymuje przetwarzanie strumieni z tej kamery przez program Frigate. Funkcje detekcji, nagrywania i debugowania będą niedostępne.ffprobe.",
"video": "Wideo:",
"codec": "Kodek:",
@@ -112,17 +125,21 @@
},
"title": "Magazyn kamery",
"camera": "Kamera",
- "storageUsed": "Wykorzystany magazyn",
+ "storageUsed": "Wykorzystana przestrzeń",
"percentageOfTotalUsed": "Procent całości",
"bandwidth": "Przepustowość",
"unusedStorageInformation": "Informacja o niewykorzystanym magazynie"
},
- "title": "Magazyn",
+ "title": "Przestrzeń dyskowa",
"overview": "Przegląd",
"recordings": {
"title": "Nagrania",
"tips": "Ta wartość reprezentuje całkowite miejsce zajmowane przez nagrania w bazie danych Frigate. Frigate nie śledzi wykorzystania magazynu dla wszystkich plików na twoim dysku.",
"earliestRecording": "Najwcześniejsze dostępne nagranie:"
+ },
+ "shm": {
+ "title": "Wykorzystanie pamięci współdzielonej SHM",
+ "warning": "Obecny rozmiar pamięci współdzielonej SHM {{total}}MB jest za mały. Zwiększ shm_size do co najmniej {{min_shm}}MB."
}
},
"logs": {
@@ -158,7 +175,8 @@
"reindexingEmbeddings": "Ponowne indeksowanie osadzeń ({{processed}}% ukończone)",
"detectIsSlow": "{{detect}} jest wolne ({{speed}} ms)",
"detectIsVerySlow": "{{detect}} jest bardzo wolne ({{speed}} ms)",
- "cameraIsOffline": "{{camera}} jest niedostępna"
+ "cameraIsOffline": "{{camera}} jest niedostępna",
+ "shmTooLow": "przydział {{total}} MB dla /dev/shm powinien zostać zwiększony do przynajmniej {{min}} MB."
},
"enrichments": {
"title": "Wzbogacenia",
@@ -174,7 +192,17 @@
"yolov9_plate_detection_speed": "Prędkość detekcji rejestracji samochodowych YOLOv9",
"yolov9_plate_detection": "Detekcja rejestracji samochodowych YOLOv9",
"text_embedding": "Osadzenie tekstu",
- "face_recognition": "Rozpoznawanie twarzy"
- }
+ "face_recognition": "Rozpoznawanie twarzy",
+ "classification_events_per_second": "{{name}} Klasyfikacja zdarzeń na sekundę",
+ "classification_speed": "{{name}} Szybkość klasyfikacji",
+ "classification": "{{name}} Klasyfikacja",
+ "review_description": "Opis recenzji",
+ "review_description_speed": "Szybkość opisu recenzji",
+ "review_description_events_per_second": "Opis recenzji",
+ "object_description": "Opis obiektu",
+ "object_description_speed": "Szybkość opisu obiektu",
+ "object_description_events_per_second": "Opis obiektu"
+ },
+ "averageInf": "Średni czas wnioskowania"
}
}
diff --git a/web/public/locales/pt-BR/audio.json b/web/public/locales/pt-BR/audio.json
index 04ee37d6b..b36f09902 100644
--- a/web/public/locales/pt-BR/audio.json
+++ b/web/public/locales/pt-BR/audio.json
@@ -1,7 +1,7 @@
{
"mantra": "Mantra",
"child_singing": "Criança cantando",
- "speech": "Discurso",
+ "speech": "Fala",
"yell": "Gritar",
"chant": "Canto",
"babbling": "Balbuciando",
@@ -425,5 +425,9 @@
"artillery_fire": "Fogo de Artilharia",
"cap_gun": "Espoleta",
"fireworks": "Fogos de Artifício",
- "firecracker": "Rojões"
+ "firecracker": "Rojões",
+ "noise": "Ruído",
+ "distortion": "Distorção",
+ "cacophony": "Cacofonia",
+ "vibration": "Vibração"
}
diff --git a/web/public/locales/pt-BR/common.json b/web/public/locales/pt-BR/common.json
index c5b789ccc..d9f30b3de 100644
--- a/web/public/locales/pt-BR/common.json
+++ b/web/public/locales/pt-BR/common.json
@@ -3,7 +3,7 @@
"untilForTime": "Até {{time}}",
"untilForRestart": "Até o Frigate reiniciar.",
"untilRestart": "Até reiniciar",
- "ago": "{{timeAgo}} antes",
+ "ago": "{{timeAgo}} atrás",
"justNow": "Agora mesmo",
"today": "Hoje",
"yesterday": "Ontem",
@@ -78,9 +78,10 @@
"formattedTimestampFilename": {
"12hour": "dd-MM-yy-hh-mm-ss",
"24hour": "dd-MM-yy-HH-mm-ss"
- }
+ },
+ "never": "Nunca"
},
- "selectItem": "Selecione {{item}}",
+ "selectItem": "Selecionar {{item}}",
"unit": {
"speed": {
"mph": "mi/h",
@@ -89,6 +90,14 @@
"length": {
"feet": "pés",
"meters": "metros"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/hora",
+ "mbph": "MB/hora",
+ "gbph": "GB/hora"
}
},
"label": {
@@ -169,7 +178,15 @@
"ca": "Català (Catalão)",
"withSystem": {
"label": "Usar as configurações de sistema para o idioma"
- }
+ },
+ "ptBR": "Português Brasileiro (Português Brasileiro)",
+ "sr": "Српски (Sérvio)",
+ "sl": "Slovenščina (Esloveno)",
+ "lt": "Lietuvių (Lituano)",
+ "bg": "Български (Búlgaro)",
+ "gl": "Galego (Galego)",
+ "id": "Bahasa Indonesia (Indonésio)",
+ "ur": "اردو (Urdu)"
},
"systemLogs": "Logs de sistema",
"settings": "Configurações",
@@ -210,7 +227,7 @@
"count_other": "{{count}} Câmeras"
}
},
- "review": "Revisão",
+ "review": "Revisar",
"explore": "Explorar",
"export": "Exportar",
"uiPlayground": "Playground da UI",
@@ -261,5 +278,9 @@
"documentTitle": "Não Encontrado - Frigate",
"title": "404",
"desc": "Página não encontrada"
+ },
+ "readTheDocumentation": "Leia a documentação",
+ "information": {
+ "pixels": "{{area}}px"
}
}
diff --git a/web/public/locales/pt-BR/components/auth.json b/web/public/locales/pt-BR/components/auth.json
index 7172acaae..27775812f 100644
--- a/web/public/locales/pt-BR/components/auth.json
+++ b/web/public/locales/pt-BR/components/auth.json
@@ -10,6 +10,7 @@
"loginFailed": "Falha no Login",
"unknownError": "Erro desconhecido. Checar registros.",
"webUnknownError": "Erro desconhecido. Verifique os logs do console."
- }
+ },
+ "firstTimeLogin": "Fazendo login pela primeira vez? As credenciais estão escritas nos logs do Frigate."
}
}
diff --git a/web/public/locales/pt-BR/components/camera.json b/web/public/locales/pt-BR/components/camera.json
index 322e63522..03ee52b58 100644
--- a/web/public/locales/pt-BR/components/camera.json
+++ b/web/public/locales/pt-BR/components/camera.json
@@ -66,7 +66,8 @@
"label": "Modo de compatibilidade",
"desc": "Habilite essa opção somente se a transmissão ao vivo da sua câmera estiver exibindo artefatos de cor e possui uma linha diagonal no canto esquerdo da imagem."
}
- }
+ },
+ "birdseye": "Visão Panorâmica"
}
},
"debug": {
diff --git a/web/public/locales/pt-BR/components/dialog.json b/web/public/locales/pt-BR/components/dialog.json
index f180fe513..c21361f85 100644
--- a/web/public/locales/pt-BR/components/dialog.json
+++ b/web/public/locales/pt-BR/components/dialog.json
@@ -53,12 +53,13 @@
"export": "Exportar",
"selectOrExport": "Selecionar ou Exportar",
"toast": {
- "success": "Exportação iniciada com sucesso. Veja o arquivo na pasta /exports.",
+ "success": "Exportação iniciada com sucesso. Veja o arquivo na tela exportar.",
"error": {
"failed": "Falha em iniciar exportação: {{error}}",
"endTimeMustAfterStartTime": "Tempo de finalização deve ser após tempo de início",
"noVaildTimeSelected": "Nenhuma faixa de tempo válida selecionada"
- }
+ },
+ "view": "Ver"
},
"fromTimeline": {
"saveExport": "Salvar Exportação",
@@ -108,7 +109,15 @@
"button": {
"markAsReviewed": "Marcar como revisado",
"export": "Exportar",
- "deleteNow": "Deletar Agora"
+ "deleteNow": "Deletar Agora",
+ "markAsUnreviewed": "Marcar como não revisado"
}
+ },
+ "imagePicker": {
+ "selectImage": "Selecionar a miniatura de um objeto rastreado",
+ "search": {
+ "placeholder": "Pesquisar por rótulo ou sub-rótulo…"
+ },
+ "noImages": "Nenhuma miniatura encontrada para essa câmera"
}
}
diff --git a/web/public/locales/pt-BR/components/filter.json b/web/public/locales/pt-BR/components/filter.json
index d503d3f13..cb76078af 100644
--- a/web/public/locales/pt-BR/components/filter.json
+++ b/web/public/locales/pt-BR/components/filter.json
@@ -23,7 +23,7 @@
"short": "Datas"
}
},
- "more": "Mais filtros",
+ "more": "Mais Filtros",
"reset": {
"label": "Resetar filtros para valores padrão"
},
@@ -71,7 +71,7 @@
"title": "Configurações",
"defaultView": {
"title": "Visualização Padrão",
- "desc": "Quando nenhum filtro é selecionado, exibir um sumário dos objetos mais recentes rastreados por categoria, ou exiba uma grade sem filtro.",
+ "desc": "Quando nenhum filtro é selecionado, exibe um sumário dos objetos mais recentes rastreados por rótulo, ou exibe uma grade sem filtro.",
"summary": "Sumário",
"unfilteredGrid": "Grade Sem Filtros"
},
@@ -106,7 +106,7 @@
},
"trackedObjectDelete": {
"title": "Confirmar Exclusão",
- "desc": "Deletar esses {{objectLength}} objetos rastreados remove as capturas de imagem, qualquer embeddings salvos, e quaisquer entradas do ciclo de vida associadas do objeto. Gravações desses objetos rastreados na visualização de Histórico NÃO irão ser deletadas.Caminhos
Linhas e círculos indicarão pontos significantes por onde o objeto rastreado se moveu durante o seu ciclo de vida.
" + }, + "audio": { + "title": "Áudio", + "noAudioDetections": "Nenhuma detecção de áudio", + "score": "pontuanção", + "currentRMS": "RMS Atual", + "currentdbFS": "dbFS Atual" + }, + "openCameraWebUI": "Abrir a Interface Web de {{camera}}" }, "users": { "title": "Usuários", "management": { "title": "Gerenciamento de Usuário", - "desc": "Gerencias as contas de usuário dessa instância do Frigate." + "desc": "Gerenciar as contas de usuário dessa instância do Frigate." }, "addUser": "Adicionar Usuário", - "updatePassword": "Atualizar Senha", + "updatePassword": "Resetar Senha", "toast": { "success": { "createUser": "Usuário {{user}} criado com sucesso", @@ -506,7 +571,8 @@ "admin": "Administrador", "adminDesc": "Acesso total a todos os recursos.", "viewer": "Espectador", - "viewerDesc": "Limitado aos Painéis ao Vivo, Revisar, Explorar, e Exportar somente." + "viewerDesc": "Limitado aos Painéis ao Vivo, Revisar, Explorar, e Exportar somente.", + "customDesc": "Papel customizado com acesso a câmeras específicas." } } }, @@ -516,7 +582,7 @@ "role": "Papel", "noUsers": "Nenhum usuário encontrado.", "changeRole": "Mudar papel do usuário", - "password": "Senha", + "password": "Resetar Senha", "deleteUser": "Deletar usuário" } }, @@ -580,7 +646,7 @@ "apiKey": { "title": "Chave de API do Frigate+", "validated": "A chave de API do Frigate+ detectada e validada", - "notValidated": "A chave de API do Frigate+ não detectada ou não validada", + "notValidated": "Chave de API do Frigate+ não detectada ou não validada", "desc": "A chave de API do Frigate+ habilita a integração com o serviço do Frigate+.", "plusLink": "Leia mais sobre o Frigate+" }, @@ -603,7 +669,7 @@ }, "snapshotConfig": { "title": "Configuração de Captura de Imagem", - "desc": "Enviar ao Frigate+ requer tanto a captura de imagem quanto a captura de imagemclean_copy estarem habilitadas na sua configuração.",
+ "desc": "Envios ao Frigate+ requerem tanto a captura de imagem normais quanto a captura de imagem clean_copy estarem habilitadas na sua configuração.",
"documentation": "Leia a documentação",
"cleanCopyWarning": "Algumas câmeras possuem captura de imagem habilitada porém têm a cópia limpa desabilitada. Você precisa habilitar a clean_copy nas suas configurações de captura de imagem para poder submeter imagems dessa câmera ao Frigate+.",
"table": {
@@ -618,5 +684,228 @@
"success": "As configurações do Frigate+ foram salvas. Reinicie o Frigate para aplicar as alterações.",
"error": "Falha ao salvar as alterações de configuração: {{errorMessage}}"
}
+ },
+ "triggers": {
+ "documentTitle": "Gatilhos",
+ "management": {
+ "title": "Gatilhos",
+ "desc": "Gerenciar gatilhos para {{camera}}. Use o tipo de miniatura para acionar miniaturas semelhantes para os seus objetos rastreados selecionados, e o tipo de descrição para acionar descrições semelhantes para textos que você especifica."
+ },
+ "addTrigger": "Adicionar Gatilho",
+ "table": {
+ "name": "Nome",
+ "type": "Tipo",
+ "content": "Conteúdo",
+ "threshold": "Limiar",
+ "actions": "Ações",
+ "noTriggers": "Nenhum gatilho configurado para essa câmera.",
+ "edit": "Editar",
+ "deleteTrigger": "Apagar Gatilho",
+ "lastTriggered": "Acionado pela última vez"
+ },
+ "type": {
+ "thumbnail": "Miniatura",
+ "description": "Descrição"
+ },
+ "actions": {
+ "alert": "Marcar como Alerta",
+ "notification": "Enviar Notificação"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "Criar Gatilho",
+ "desc": "Criar gatilho para a câmera {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Editar Gatilho",
+ "desc": "Editar as configurações de gatilho na câmera {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Apagar Gatilho",
+ "desc": "Tem certeza que quer deletar o gatilho {{triggerName}}? Essa ação não pode ser desfeita."
+ },
+ "form": {
+ "name": {
+ "title": "Nome",
+ "placeholder": "Nomeie este gatilho",
+ "error": {
+ "minLength": "O campo precisa ter no mínimo 2 caracteres.",
+ "invalidCharacters": "O campo pode contar apenas letras, números, sublinhados, e hifens.",
+ "alreadyExists": "Um gatilho com esse nome já existe para essa câmera."
+ }
+ },
+ "enabled": {
+ "description": "Habilitar ou desabilitar esse gatilho"
+ },
+ "type": {
+ "title": "Tipo",
+ "placeholder": "Selecionar o tipo de gatilho"
+ },
+ "content": {
+ "title": "Conteúdo",
+ "imagePlaceholder": "Selecionar um thumbnail",
+ "textPlaceholder": "Digitar conteúdo do texto",
+ "imageDesc": "Selecionar uma imagem para acionar essa ação quando uma imagem semelhante for detectada.",
+ "textDesc": "Digite o texto para ativar essa ação quando uma descrição semelhante de objeto rastreado for detectada.",
+ "error": {
+ "required": "Um conteúdo é requerido."
+ }
+ },
+ "threshold": {
+ "title": "Limiar",
+ "error": {
+ "min": "O limitar deve ser no mínimo 0",
+ "max": "O limiar deve ser no mínimo 1"
+ }
+ },
+ "actions": {
+ "title": "Ações",
+ "desc": "Por padrão, o Frigate dispara uma mensagem MQTT para todos os gatilhos. Escolha uma ação adicional para realizar quando uma ação for disparada.",
+ "error": {
+ "min": "Ao menos uma ação deve ser selecionada."
+ }
+ },
+ "friendly_name": {
+ "title": "Nome Amigável",
+ "placeholder": "Nomeie ou descreva esse gatilho",
+ "description": "Um nome amigável ou descritivo opcional para esse gatilho."
+ }
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Gatilho {{name}} criado com sucesso.",
+ "updateTrigger": "Gatilho {{name}} atualizado com sucesso.",
+ "deleteTrigger": "Gatilho {{name}} apagado com sucesso."
+ },
+ "error": {
+ "createTriggerFailed": "Falha ao criar gatilho: {{errorMessage}}",
+ "updateTriggerFailed": "Falha ao atualizar gatilho: {{errorMessage}}",
+ "deleteTriggerFailed": "Falha ao apagar gatilho: {{errorMessage}}"
+ }
+ },
+ "semanticSearch": {
+ "title": "Busca Semântica desativada",
+ "desc": "Busca Semântica deve estar habilitada para usar os Gatilhos."
+ }
+ },
+ "roles": {
+ "management": {
+ "title": "Gerenciamento do Papel de Visualizador",
+ "desc": "Gerenciar papéis de visualizador customizados e suas permissões de acesso para essa instância do Frigate."
+ },
+ "addRole": "Adicionar Papel",
+ "table": {
+ "role": "Papel",
+ "cameras": "Câmeras",
+ "actions": "Ações",
+ "noRoles": "Nenhum papel customizado encontrado.",
+ "editCameras": "Editar Câmeras",
+ "deleteRole": "Apagar Papel"
+ },
+ "toast": {
+ "success": {
+ "createRole": "Papel {{role}} criado com sucesso",
+ "updateCameras": "Câmeras atualizados para o papel {{role}}",
+ "deleteRole": "Papel {{role}} apagado com sucesso",
+ "userRolesUpdated_one": "{{count}} usuário atribuído a essa função foi atualizado para 'visualizador', com acesso a todas as câmeras.",
+ "userRolesUpdated_many": "{{count}} usuários atribuídos a essa função foram atualizados para 'visualizador', com acesso a todas as câmeras.",
+ "userRolesUpdated_other": "{{count}} usuários atribuídos a esse papel foram atualizados para 'visualizador', com acesso a todas as câmeras."
+ },
+ "error": {
+ "createRoleFailed": "Falha ao criar papel: {{errorMessage}}",
+ "updateCamerasFailed": "Falha ao atualizar câmeras: {{errorMessage}}",
+ "deleteRoleFailed": "Falha ao apagar papel: {{errorMessage}}",
+ "userUpdateFailed": "Falha ao atualizar papel do usuário: {{errorMessage}}"
+ }
+ },
+ "dialog": {
+ "createRole": {
+ "title": "Criar Novo Papel",
+ "desc": "Adicionar um novo papel e especificar permissões de acesso."
+ },
+ "editCameras": {
+ "title": "Editar Câmeras de Papéis",
+ "desc": "Atualizar acesso da câmera para o papel {{role}}."
+ },
+ "deleteRole": {
+ "title": "Deletar Papel",
+ "desc": "Essa ação não pode ser desfeita. Isso irá apagar permanentemente o papel e atribuir a quaisquer usuários com esse papel como 'visualizador', o que dará acesso de visualização para todas as câmeras.",
+ "warn": "Tem certeza que quer apagar {{role}}?",
+ "deleting": "Apagando…"
+ },
+ "form": {
+ "role": {
+ "title": "Nome do Papel",
+ "placeholder": "Digitar nome do papel",
+ "desc": "Apenas letras, números, pontos e sublinhados são permitidos.",
+ "roleIsRequired": "Nome para o papel é requerido",
+ "roleOnlyInclude": "O nome do papel pode conter apenas letras, números, pontos ou sublinhados",
+ "roleExists": "Um papel com esse nome já existe."
+ },
+ "cameras": {
+ "title": "Câmeras",
+ "desc": "Selecione as câmeras que esse papel terá acesso. Ao menos uma câmera é requerida.",
+ "required": "Ao menos uma câmera deve ser selecionada."
+ }
+ }
+ }
+ },
+ "cameraWizard": {
+ "title": "Adicionar Câmera",
+ "description": "Siga os passos abaixo para adicionar uma câmera nova no seu Frigate.",
+ "steps": {
+ "nameAndConnection": "Nome e Conexão",
+ "streamConfiguration": "Configuração de Stream",
+ "validationAndTesting": "Validação e Teste"
+ },
+ "save": {
+ "success": "Nova câmera {{cameraName}} salva com sucesso.",
+ "failure": "Erro ao salvar {{cameraName}}."
+ },
+ "testResultLabels": {
+ "resolution": "Resolução",
+ "video": "Vídeo",
+ "audio": "Áudio",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Favor fornecer uma URL de stream válida",
+ "testFailed": "Teste de stream falhou: {{error}}"
+ },
+ "step1": {
+ "description": "Insira os detalhes da sua câmera e escolha entre sondar a câmera ou selecionar a marca manualmente.",
+ "cameraName": "Nome da Câmera",
+ "cameraNamePlaceholder": "ex., porta_entrada ou Visão Geral do Quintal",
+ "host": "Host/Endereço IP",
+ "port": "Porta",
+ "username": "Nome de Usuário",
+ "usernamePlaceholder": "Opcional",
+ "password": "Senha",
+ "passwordPlaceholder": "Opcional",
+ "selectTransport": "Selecionar protocolo de transporte",
+ "cameraBrand": "Marca da Câmera",
+ "selectBrand": "Selecione a marca da câmera para template de URL",
+ "customUrl": "URL Customizada de Stream",
+ "brandInformation": "Informação da marca",
+ "brandUrlFormat": "Para câmeras com o formato de URL RTSP como: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://nomedeusuario:senha@host:porta/caminho",
+ "testConnection": "Testar Conexão",
+ "testSuccess": "Teste de conexão bem sucedido!",
+ "testFailed": "Teste de conexão falhou. Favor verifique os dados e tente novamente.",
+ "streamDetails": "Detalhes do Stream",
+ "warnings": {
+ "noSnapshot": "Não foi possível adquirir uma captura de imagem do stream configurado."
+ },
+ "errors": {
+ "brandOrCustomUrlRequired": "Selecione a marca da câmera com o host/IP or selecione 'Outro' com uma URL customizada",
+ "nameRequired": "Nome para a câmera requerido",
+ "nameLength": "O nome da câmera deve ter 64 caracteres ou menos"
+ },
+ "testing": {
+ "probingMetadata": "Inferindo o metadata da câmera...",
+ "fetchingSnapshot": "Buscando a captura de imagem da câmera..."
+ }
+ }
}
}
diff --git a/web/public/locales/pt-BR/views/system.json b/web/public/locales/pt-BR/views/system.json
index 74a2c4564..4875d8015 100644
--- a/web/public/locales/pt-BR/views/system.json
+++ b/web/public/locales/pt-BR/views/system.json
@@ -42,7 +42,8 @@
"inferenceSpeed": "Velocidade de Inferência do Detector",
"temperature": "Detector Temperatura",
"cpuUsage": "Utilização de CPU de Detecção",
- "memoryUsage": "Utilização de Memória do Detector"
+ "memoryUsage": "Utilização de Memória do Detector",
+ "cpuUsageInformation": "CPU utilizado para preparar os dados de entrada e saída de/para os modelos de detecção. Esse valor não mede a utilização da inferência, mesmo se estiver usando um GPU ou acelerador."
},
"hardwareInfo": {
"title": "Informações de Hardware",
@@ -102,6 +103,10 @@
"title": "Não Utilizado",
"tips": "Esse valor por não representar com precisão o espaço livre disponí®el para o Frigate se você possui outros arquivos armazenados no seu drive além das gravações do Frigate. O Frigate não rastreia a utilização do armazenamento além de suas próprias gravações."
}
+ },
+ "shm": {
+ "title": "Alocação de memória compartilhada (SHM)",
+ "warning": "O tamanho de {{total}}MB de memória compartilhada (SHM) é insuficiente. Aumente para ao menos {{min_shm}}MB."
}
},
"cameras": {
@@ -157,8 +162,9 @@
"detectHighCpuUsage": "{{camera}} possui alta utilização de CPU para detecção ({{detectAvg}}%)",
"healthy": "O sistema está saudável",
"cameraIsOffline": "{{camera}} está offline",
- "reindexingEmbeddings": "Reindexando os vetores de característica de imagens ({{processed}}% completado)",
- "detectIsSlow": "{{detect}} está lento ({{speed}} ms)"
+ "reindexingEmbeddings": "Reindexando os embeddings ({{processed}}% completado)",
+ "detectIsSlow": "{{detect}} está lento ({{speed}} ms)",
+ "shmTooLow": "A alocação ({{total}} MB) para a pasta /dev/shm deve ser aumentada para ao menos {{min}} MB."
},
"enrichments": {
"title": "Enriquecimentos",
@@ -167,13 +173,13 @@
"face_recognition": "Reconhecimento Facial",
"plate_recognition": "Reconhecimento de Placa",
"plate_recognition_speed": "Velocidade de Reconhecimento de Placas",
- "text_embedding_speed": "Velocidade de Geração de Vetores de Texto",
+ "text_embedding_speed": "Velocidade de Embeddings de Texto",
"yolov9_plate_detection_speed": "Velocidade de Reconhecimento de Placas do YOLOv9",
"yolov9_plate_detection": "Detecção de Placas do YOLOv9",
- "image_embedding": "Vetores de Características de Imagens",
- "text_embedding": "Vetor de Característica de Texto",
- "image_embedding_speed": "Velocidade de Geração de Vetores de Imagem",
- "face_embedding_speed": "Velocidade de Geração de Vetores de Rostos",
+ "image_embedding": "Embeddings de Imagens",
+ "text_embedding": "Embeddings de Texto",
+ "image_embedding_speed": "Velocidade de Embeddings de Imagens",
+ "face_embedding_speed": "Velocidade de Embedding de Rostos",
"face_recognition_speed": "Velocidade de Reconhecimento de Rostos"
}
}
diff --git a/web/public/locales/pt/audio.json b/web/public/locales/pt/audio.json
index 36b414716..3bf1ba60b 100644
--- a/web/public/locales/pt/audio.json
+++ b/web/public/locales/pt/audio.json
@@ -1,8 +1,8 @@
{
- "babbling": "Balbuciar",
+ "babbling": "Falador",
"speech": "Discurso",
"whoop": "Grito de Alegria",
- "bellow": "Abaixo",
+ "bellow": "Debaixo",
"yell": "Gritar",
"whispering": "Sussurrar",
"child_singing": "Criança a Cantar",
@@ -14,7 +14,7 @@
"meow": "Miau",
"run": "Correr",
"sheep": "Ovelha",
- "motorcycle": "Motociclo",
+ "motorcycle": "Mota",
"car": "Carro",
"cat": "Gato",
"horse": "Cavalo",
@@ -33,15 +33,15 @@
"whistling": "Assobiar",
"wheeze": "Chiadeira",
"gasp": "Ofegar",
- "cough": "Tosse",
- "sneeze": "Espirro",
+ "cough": "Tossir",
+ "sneeze": "Espirrar",
"footsteps": "Passos",
"chewing": "Mastigar",
"biting": "Morder",
"gargling": "Gargarejar",
"stomach_rumble": "Ronco de Estômago",
"burping": "Arroto",
- "hiccup": "Solavanco",
+ "hiccup": "Soluço",
"fart": "Pum",
"hands": "Mãos",
"finger_snapping": "Estalar os Dedos",
@@ -109,7 +109,7 @@
"helicopter": "Helicóptero",
"engine": "Motor",
"coin": "Moeda",
- "scissors": "Tesoura",
+ "scissors": "Tesouras",
"electric_shaver": "Barbeador Elétrico",
"computer_keyboard": "Teclado de Computador",
"alarm": "Alarme",
@@ -145,12 +145,12 @@
"owl": "Coruja",
"mouse": "Rato",
"vehicle": "Veículo",
- "hair_dryer": "Secador de cabelo",
- "toothbrush": "Escova de dentes",
- "sink": "Pia",
+ "hair_dryer": "Secador de Cabelo",
+ "toothbrush": "Escova de Dentes",
+ "sink": "Banca",
"blender": "Liquidificador",
"pant": "Ofegar",
- "snort": "Espirrar pelo Nariz",
+ "snort": "Resfolegar",
"throat_clearing": "Limpar a Garganta",
"sniff": "Cheirar",
"shuffle": "Embaralhar",
diff --git a/web/public/locales/pt/common.json b/web/public/locales/pt/common.json
index ad63195c1..557d6b48d 100644
--- a/web/public/locales/pt/common.json
+++ b/web/public/locales/pt/common.json
@@ -2,13 +2,13 @@
"time": {
"last30": "Últimos 30 dias",
"12hours": "12 horas",
- "justNow": "Agora",
+ "justNow": "Agora mesmo",
"yesterday": "Ontem",
"today": "Hoje",
"last7": "Últimos 7 dias",
"last14": "Últimos 14 dias",
- "thisWeek": "Essa semana",
- "lastWeek": "Semana passada",
+ "thisWeek": "Esta Semana",
+ "lastWeek": "Semana Passada",
"5minutes": "5 minutos",
"10minutes": "10 minutos",
"30minutes": "30 minutos",
@@ -18,14 +18,14 @@
"year_one": "{{time}} ano",
"year_many": "{{time}} de anos",
"year_other": "{{time}} anos",
- "month_one": "{{time}} mes",
+ "month_one": "{{time}} mês",
"month_many": "{{time}} meses",
- "month_other": "",
+ "month_other": "{{time}} meses",
"day_one": "{{time}} dia",
"day_many": "{{time}} dias",
"day_other": "{{time}} dias",
- "thisMonth": "Esse mês",
- "lastMonth": "Mês passado",
+ "thisMonth": "Este Mês",
+ "lastMonth": "Mês Passado",
"1hour": "1 hora",
"hour_one": "{{time}} hora",
"hour_many": "{{time}} horas",
@@ -39,7 +39,7 @@
"untilForTime": "Até {{time}}",
"untilForRestart": "Até que o Frigate reinicie.",
"untilRestart": "Até reiniciar",
- "ago": "{{timeAgo}} atrás",
+ "ago": "há {{timeAgo}}",
"d": "{{time}}d",
"h": "{{time}}h",
"m": "{{time}}m",
@@ -87,68 +87,85 @@
"formattedTimestampMonthDayYear": {
"12hour": "d MMM, yyyy",
"24hour": "d MMM, yyyy"
- }
+ },
+ "inProgress": "Em andamento",
+ "invalidStartTime": "Horário de início inválido",
+ "invalidEndTime": "Horário de término inválido"
},
"unit": {
"speed": {
- "kph": "kph",
+ "kph": "km/h",
"mph": "mph"
},
"length": {
- "feet": "pé",
+ "feet": "pés",
"meters": "metros"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/hora",
+ "mbph": "MB/hora",
+ "gbph": "GB/hora"
}
},
"button": {
- "enabled": "Habilitado",
- "enable": "Habilitar",
+ "enabled": "Ativado",
+ "enable": "Ativar",
"done": "Feito",
"reset": "Reiniciar",
- "disabled": "Desabilitado",
- "saving": "Salvando…",
+ "disabled": "Desativado",
+ "saving": "A guardar…",
"apply": "Aplicar",
- "disable": "Desabilitar",
+ "disable": "Desativar",
"save": "Salvar",
- "copy": "Cópia",
+ "copy": "Copiar",
"cancel": "Cancelar",
"close": "Fechar",
"history": "Histórico",
"back": "Voltar",
"fullscreen": "Ecrã Completo",
"exitFullscreen": "Sair do Ecrã Completo",
- "twoWayTalk": "Conversa bidirecional",
- "cameraAudio": "Áudio da câmera",
+ "twoWayTalk": "Conversa Bidirecional",
+ "cameraAudio": "Áudio da Câmera",
"edit": "Editar",
"off": "DESLIGADO",
"copyCoordinates": "Copiar coordenadas",
"on": "LIGADO",
- "delete": "Excluir",
- "download": "Download",
- "info": "Informações",
+ "delete": "Eliminar",
+ "download": "Transferir",
+ "info": "Informação",
"no": "Não",
"suspended": "Suspenso",
"yes": "Sim",
- "unselect": "Desmarcar",
+ "unselect": "Desselecionar",
"unsuspended": "Dessuspender",
- "deleteNow": "Excluir agora",
+ "deleteNow": "Eliminar Agora",
"export": "Exportar",
- "next": "Próximo",
+ "next": "Seguinte",
"play": "Tocar",
- "pictureInPicture": "Sobrepor Imagem"
+ "pictureInPicture": "Imagem sobre Imagem",
+ "continue": "Continuar"
},
"label": {
- "back": "Voltar"
+ "back": "Voltar",
+ "hide": "Ocultar {{item}}",
+ "show": "Exibir {{item}}",
+ "ID": "ID",
+ "none": "Nenhum",
+ "all": "Todos"
},
"menu": {
"user": {
- "logout": "Sair",
+ "logout": "Terminar sessão",
"account": "Conta",
"current": "Utilizador atual: {{user}}",
- "setPassword": "Definir senha",
+ "setPassword": "Definir Palavra-passe",
"title": "Utilizador",
- "anonymous": "anônimo"
+ "anonymous": "anónimo"
},
- "faceLibrary": "Biblioteca de rostos",
+ "faceLibrary": "Biblioteca de Rostos",
"withSystem": "Sistema",
"theme": {
"label": "Tema",
@@ -156,58 +173,66 @@
"green": "Verde",
"red": "Vermelho",
"contrast": "Alto contraste",
- "default": "Padrão",
+ "default": "Predefinição",
"highcontrast": "Alto Contraste",
"nord": "Nord"
},
"system": "Sistema",
"systemMetrics": "Métricas do sistema",
"configuration": "Configuração",
- "systemLogs": "Logs do sistema",
- "settings": "Configurações",
- "configurationEditor": "Editor de configuração",
+ "systemLogs": "Registos do sistema",
+ "settings": "Definições",
+ "configurationEditor": "Editor de Configuração",
"languages": "Idiomas",
"language": {
- "en": "Inglês (English)",
- "zhCN": "Chinês simplificado",
+ "en": "Inglês (EUA)",
+ "zhCN": "简体中文 (Chinês Simplificado)",
"withSystem": {
- "label": "Use as configurações do sistema para idioma"
+ "label": "Utilizar as definições do sistema para o idioma"
},
- "fr": "Français (Francês)",
- "es": "Español (Espanhol)",
- "ru": "Русский (Russo)",
- "de": "Deutsch (Alemão)",
- "ja": "日本語 (Japonês)",
- "yue": "Cantonês (粵語)",
- "ar": "العربية (Arabic)",
- "uk": "Ucraniano (Українська)",
- "el": "Grego (Ελληνικά)",
- "hi": "हिन्दी (Hindi)",
- "pt": "Português (Portuguese)",
- "tr": "Türkçe (Turkish)",
- "it": "Italiano (Italian)",
- "nb": "Norueguês Bokmål (Norsk Bokmål)",
- "ko": "Coreano (한국어)",
- "vi": "Vietnamita (Tiếng Việt)",
- "nl": "Nederlands (Dutch)",
- "sv": "Svenska (Swedish)",
- "cs": "Tcheco (Čeština)",
- "fa": "Persa (فارسی)",
- "pl": "Polonês (Polski)",
- "he": "Hebraico (עברית)",
- "fi": "Finlandês (Suomi)",
- "da": "Dinamarquês (Dansk)",
- "ro": "Romeno (Română)",
- "hu": "Húngaro (Magyar)",
- "sk": "Eslovaco (Slovenčina)",
+ "fr": "Francês (França)",
+ "es": "Espanhol (Espanha)",
+ "ru": "Russo",
+ "de": "Alemão (Alemanha)",
+ "ja": "Japonês",
+ "yue": "Cantonês",
+ "ar": "Árabe",
+ "uk": "Ucraniano",
+ "el": "Grego",
+ "hi": "Híndi (Índia)",
+ "pt": "Português (Portugal)",
+ "tr": "Turco (Turquia)",
+ "it": "Italiano (Itália)",
+ "nb": "Norueguês Bokmål",
+ "ko": "Coreano",
+ "vi": "Vietnamita",
+ "nl": "Holandês (Holanda)",
+ "sv": "Sueco",
+ "cs": "Checo",
+ "fa": "Persa",
+ "pl": "Polaco",
+ "he": "Hebraico",
+ "fi": "Finlandês",
+ "da": "Dinamarquês",
+ "ro": "Romeno",
+ "hu": "Húngaro",
+ "sk": "Eslovaco",
"th": "Tailandês",
- "ca": "Català (Catalão)"
+ "ca": "Catalão",
+ "ptBR": "Português (Brazil)",
+ "sr": "Sérvio",
+ "sl": "Esloveno",
+ "lt": "Lituano",
+ "bg": "Búlgaro",
+ "gl": "Galego",
+ "id": "Indonésio Bahasa",
+ "ur": "Urdu"
},
"appearance": "Aparência",
"darkMode": {
- "label": "Modo escuro",
+ "label": "Modo Escuro",
"withSystem": {
- "label": "Use as configurações do sistema para o modo claro ou escuro"
+ "label": "Utilizar as definições do sistema para o modo claro ou escuro"
},
"light": "Claro",
"dark": "Escuro"
@@ -220,7 +245,7 @@
"restart": "Reiniciar Frigate",
"live": {
"title": "Ao vivo",
- "allCameras": "Todas as câmaras",
+ "allCameras": "Todas as Câmaras",
"cameras": {
"title": "Câmaras",
"count_one": "{{count}} Câmera",
@@ -230,8 +255,9 @@
},
"export": "Exportar",
"explore": "Explorar",
- "review": "Análise",
- "uiPlayground": "Área de Testes da Interface"
+ "review": "Rever",
+ "uiPlayground": "Área de Testes da IU",
+ "classification": "Classificação"
},
"pagination": {
"previous": {
@@ -240,36 +266,49 @@
},
"label": "paginação",
"next": {
- "title": "Próximo",
- "label": "Ir para a próxima página"
+ "title": "Seguinte",
+ "label": "Ir para a página seguinte"
},
"more": "Mais páginas"
},
"role": {
"admin": "Administrador",
"viewer": "Visualizador",
- "title": "Regra",
- "desc": "Administradores têm acesso total a todos os recursos da interface do Frigate. Visualizadores estão limitados a visualizar câmeras, revisar itens e assistir o histórico de gravaçoes na interface."
+ "title": "Função",
+ "desc": "Os administradores têm acesso completo a todas as funcionalidades da IU do Frigate. Os visualizadores estão limitados a visualizar as câmeras, rever itens, e o histórico de gravaçoes na IU."
},
"toast": {
- "copyUrlToClipboard": "URL copiada para a área de transferência.",
+ "copyUrlToClipboard": "URL copiado para a área de transferência.",
"save": {
- "title": "Salvar",
+ "title": "Guardar",
"error": {
- "noMessage": "Falha ao salvar as alterações de configuração",
- "title": "Falha ao salvar as alterações de configuração: {{errorMessage}}"
+ "noMessage": "Não foi possível guardar as alterações da configuração",
+ "title": "Não foi possível guardar as alterações da configuração: {{errorMessage}}"
}
}
},
"accessDenied": {
- "documentTitle": "Acesso negado - Frigate",
- "title": "Acesso negado",
- "desc": "Você não tem permissão para visualizar esta página."
+ "documentTitle": "Frigate - Acesso Negado",
+ "title": "Acesso Negado",
+ "desc": "Não tem permissão para ver esta página."
},
"notFound": {
- "documentTitle": "Não encontrado - Frigate",
+ "documentTitle": "Frigate - Não Encontrado",
"desc": "Página não encontrada",
"title": "404"
},
- "selectItem": "Selecionar {{item}}"
+ "selectItem": "Selecionar {{item}}",
+ "readTheDocumentation": "Leia a documentação",
+ "information": {
+ "pixels": "{{area}}px"
+ },
+ "list": {
+ "two": "{{0}} e {{1}}",
+ "many": "{{items}} e {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Opcional",
+ "internalID": "o Frigate utiliza o ID na configuração e no banco de dados"
+ }
}
diff --git a/web/public/locales/pt/components/auth.json b/web/public/locales/pt/components/auth.json
index 5dcccd7d6..3fa777ba8 100644
--- a/web/public/locales/pt/components/auth.json
+++ b/web/public/locales/pt/components/auth.json
@@ -1,15 +1,16 @@
{
"form": {
"user": "Nome do utilizador",
- "login": "Login",
+ "login": "Iniciar sessão",
"errors": {
"usernameRequired": "O nome do utilizador é obrigatório",
- "passwordRequired": "Senha é necessária",
+ "passwordRequired": "A palavra-passe é obrigatória",
"rateLimit": "Limite de taxa excedido. Tente novamente mais tarde.",
- "loginFailed": "Falha no login",
- "unknownError": "Erro desconhecido. Verifique os logs.",
- "webUnknownError": "Erro desconhecido. Verifique os logs da consola."
+ "loginFailed": "Autenticação falhou",
+ "unknownError": "Erro desconhecido. Verifique os registos.",
+ "webUnknownError": "Erro desconhecido. Verifique os registos da consola."
},
- "password": "Senha"
+ "password": "Palavra-passe",
+ "firstTimeLogin": "Está tentando fazer login pela primeira vez? As credenciais estão impressas nos registros do Frigate."
}
}
diff --git a/web/public/locales/pt/components/camera.json b/web/public/locales/pt/components/camera.json
index fa4a5fdc1..3f7052c81 100644
--- a/web/public/locales/pt/components/camera.json
+++ b/web/public/locales/pt/components/camera.json
@@ -1,27 +1,27 @@
{
"group": {
- "label": "Grupos de câmaras",
- "add": "Adicionar grupo de câmaras",
- "edit": "Editar grupo de câmaras",
+ "label": "Grupos de Câmaras",
+ "add": "Adicionar Gupo de Câmaras",
+ "edit": "Editar Grupo de Câmaras",
"delete": {
- "label": "Excluir grupo de câmaras",
+ "label": "Eliminar Grupo de Câmaras",
"confirm": {
- "title": "Confirmar exclusão",
- "desc": "Tem certeza de que deseja excluir o grupo de câmaras {{name}}?"
+ "title": "Confirmar Eliminar",
+ "desc": "Tem a certeza que deseja eliminar o grupo de câmaras {{name}}?"
}
},
"name": {
"label": "Nome",
- "placeholder": "Digita um nome…",
+ "placeholder": "Inserir um nome…",
"errorMessage": {
"exists": "O nome do grupo de câmaras já existe.",
"nameMustNotPeriod": "O nome do grupo de câmaras não deve conter pontos.",
- "mustLeastCharacters": "O nome do grupo de câmaras deve ter pelo menos 2 caracteres.",
- "invalid": "Nome de grupo de câmaras inválido."
+ "mustLeastCharacters": "O nome do grupo de câmaras deve ter pelo menos 2 carateres.",
+ "invalid": "Nome do grupo de câmaras inválido."
}
},
"cameras": {
- "desc": "Selecione câmaras para este grupo.",
+ "desc": "Selecione as câmaras para este grupo.",
"label": "Câmaras"
},
"icon": "Ícone",
@@ -37,17 +37,17 @@
}
},
"streamMethod": {
- "label": "Método de transmissão",
+ "label": "Método de Transmissão",
"method": {
"smartStreaming": {
- "label": "Transmissão inteligente (recomendado)",
- "desc": "A transmissão inteligente atualizará a imagem da sua câmara uma vez por minuto quando nenhuma atividade detectável estiver ocorrendo para conservar largura de banda e recursos. Quando a atividade é detectada, a imagem muda perfeitamente para uma transmissão ao vivo."
+ "label": "Transmissão Inteligente (recomendado)",
+ "desc": "A transmissão inteligente atualizará a imagem da sua câmara uma vez por minuto quando não ocorrer nenhuma atividade detetável para conservar largura de banda e recursos. Quando a atividade é detetada, a imagem muda perfeitamente para uma transmissão ao vivo."
},
"continuousStreaming": {
- "label": "Transmissão contínua",
+ "label": "Transmissão Contínua",
"desc": {
- "warning": "A transmissão contínua pode causar alto uso de largura de banda e problemas de desempenho. Use com precaução.",
- "title": "A imagem da câmara sempre será uma transmissão ao vivo quando visível no painel, mesmo que nenhuma atividade esteja sendo detectada."
+ "warning": "A transmissão contínua pode causar a utilização alta da largura de banda e problemas de desempenho. Utilize com precaução.",
+ "title": "A imagem da câmara será sempre uma transmissão ao vivo quando visível no painel, mesmo que não esteja a ser detetada nenhuma atividade."
}
},
"noStreaming": {
@@ -59,24 +59,25 @@
},
"compatibilityMode": {
"label": "Modo de compatibilidade",
- "desc": "Habilite esta opção somente se a transmissão ao vivo da sua câmara estiver exibindo artefatos de cor e tiver uma linha diagonal no lado direito da imagem."
+ "desc": "Ative esta opção apenas se a transmissão ao vivo da sua câmara estiver a exibir artefatos de cor e tiver uma linha diagonal no lado direito da imagem."
},
- "label": "Configurações de transmissão da câmara",
- "desc": "Altere as opções de transmissão ao vivo para o painel deste grupo de câmaras. Essas configurações são específicas do dispositivo/navegador.",
- "title": "{{cameraName}} configurações de transmissão",
+ "label": "Definições de Transmissão da Câmara",
+ "desc": "Altere as opções de transmissão ao vivo para o painel deste grupo de câmaras. Estas definições são específicas do dispositivo/navegador.",
+ "title": "{{cameraName}} Definições de Transmissão",
"placeholder": "Escolha uma transmissão",
"stream": "Transmissão"
- }
+ },
+ "birdseye": "Vista Aérea"
}
},
"debug": {
"options": {
- "label": "Configurações",
+ "label": "Definições",
"title": "Opções",
- "hideOptions": "Ocultar opções",
- "showOptions": "Mostrar opções"
+ "hideOptions": "Ocultar Opções",
+ "showOptions": "Mostrar Opções"
},
- "boundingBox": "Caixa delimitadora",
+ "boundingBox": "Caixa Delimitadora",
"timestamp": "Carimbo de hora",
"zones": "Zonas",
"mask": "Máscara",
diff --git a/web/public/locales/pt/components/dialog.json b/web/public/locales/pt/components/dialog.json
index 766711539..b1aeb06c1 100644
--- a/web/public/locales/pt/components/dialog.json
+++ b/web/public/locales/pt/components/dialog.json
@@ -2,17 +2,17 @@
"restart": {
"button": "Reiniciar",
"restarting": {
- "title": "Frigate está reiniciando",
+ "title": "Frigate está a reiniciar",
"content": "Esta página será recarregada em {{countdown}} segundos.",
- "button": "Forçar atualização agora"
+ "button": "Forçar Recarregar Agora"
},
- "title": "Tem certeza de que deseja reiniciar o Frigate?"
+ "title": "Tem a certeza que deseja reiniciar o Frigate?"
},
"explore": {
"plus": {
"submitToPlus": {
- "label": "Enviar para Frigate+",
- "desc": "Objetos em locais que você quer evitar não são falsos positivos. Enviá-los como falsos positivos confundirá o modelo."
+ "label": "Submeter para Frigate+",
+ "desc": "Os objetos nas localizações que quer evitar não são falsos positivos. Submete-los como falsos positivos confundirá o modelo."
},
"review": {
"true": {
@@ -22,7 +22,7 @@
"true_other": "Estão são {{label}}"
},
"state": {
- "submitted": "Enviado"
+ "submitted": "Submetido"
},
"false": {
"label": "Não confirmar esta etiqueta para Frigate Plus",
@@ -31,15 +31,15 @@
"false_other": "Estes não são {{label}}"
},
"question": {
- "label": "Confirme este rótulo para Frigate Plus",
+ "label": "Confirme esta etiqueta para Frigate Plus",
"ask_a": "Este objeto é um {{label}}?",
"ask_an": "Este objeto é um {{label}}?",
- "ask_full": "Este objeto é um(a) {{untranslatedLabel}} ({{translatedLabel}})?"
+ "ask_full": "Este objeto é um {{untranslatedLabel}} ({{translatedLabel}})?"
}
}
},
"video": {
- "viewInHistory": "Ver no histórico"
+ "viewInHistory": "Ver no Histórico"
}
},
"export": {
@@ -60,67 +60,74 @@
},
"export": "Exportar",
"toast": {
- "success": "Exportação iniciada com sucesso. Veja o arquivo na pasta /exports.",
+ "success": "Exportação iniciada com sucesso. Veja o ficheiro na pasta de exportações.",
"error": {
- "failed": "Falha ao iniciar a exportação: {{error}}",
+ "failed": "Não foi possível iniciar a exportação: {{error}}",
"endTimeMustAfterStartTime": "O horário de término deve ser posterior ao horário de início",
"noVaildTimeSelected": "Nenhum intervalo de tempo válido selecionado"
}
},
"selectOrExport": "Selecionar ou Exportar",
"fromTimeline": {
- "saveExport": "Salvar exportação",
- "previewExport": "Visualizar exportação"
+ "saveExport": "Guardar Exportação",
+ "previewExport": "Pré-visualizar Exportação"
},
- "select": "Selecione",
+ "select": "Selecionar",
"name": {
- "placeholder": "Nome da exportação"
+ "placeholder": "Nome da Exportação"
}
},
"streaming": {
"showStats": {
"label": "Mostrar estatísticas de transmissão",
- "desc": "Habilite esta opção para mostrar estatísticas de transmissão como uma sobreposição no feed da câmara."
+ "desc": "Ative esta opção para mostrar as estatísticas de transmissão como uma sobreposição na feed da câmara."
},
"restreaming": {
"desc": {
- "title": "Configure o go2rtc para obter opções adicionais de visualização ao vivo e áudio para esta câmara.",
+ "title": "Configure go2rtc para obter opções adicionais da visualização ao vivo e o áudio para esta câmara.",
"readTheDocumentation": "Leia a documentação"
},
- "disabled": "A retransmissão não está habilitada para esta câmara."
+ "disabled": "A retransmissão não está ativada para esta câmara."
},
"label": "Transmissão",
- "debugView": "Exibição de depuração"
+ "debugView": "Ver Depuração"
},
"search": {
"saveSearch": {
- "label": "Salvar pesquisa",
- "overwrite": "{{searchName}} já existe. Salvar substituirá o valor existente.",
- "success": "A pesquisa ({{searchName}}) foi salva.",
+ "label": "Guardar Procura",
+ "overwrite": "{{searchName}} já existe. Ao guardar irá substituir o valor existente.",
+ "success": "A procura ({{searchName}}) foi guardada.",
"button": {
"save": {
- "label": "Salvar esta pesquisa"
+ "label": "Guardar esta procura"
}
},
- "placeholder": "Digite um nome para sua pesquisa",
- "desc": "Forneça um nome para esta pesquisa salva."
+ "placeholder": "Insira um nome para a sua procura",
+ "desc": "Forneça um nome para esta procura guardada."
}
},
"recording": {
"confirmDelete": {
- "title": "Confirmar exclusão",
+ "title": "Confirmar Eliminar",
"desc": {
- "selected": "Tem certeza de que deseja excluir todos os vídeos gravados associados a este item de analise?detecção {{cameraName}}, verifique os logs de erro"
},
"cameraDisabled": "A câmara está desativada",
@@ -29,23 +29,23 @@
},
"totalFrames": "Total de quadros:",
"droppedFrames": {
- "title": "Quadros perdidos:",
+ "title": "Imagens perdidas:",
"short": {
- "title": "Perdido",
- "value": "{{droppedFrames}} quadros"
+ "title": "Perdida",
+ "value": "{{droppedFrames}} imagens"
}
},
"decodedFrames": "Quadros decodificados:",
- "droppedFrameRate": "Taxa de Quadros Perdidos:"
+ "droppedFrameRate": "Taxa de imagem perdida:"
},
"noRecordingsFoundForThisTime": "Nenhuma gravação encontrada para este momento",
- "livePlayerRequiredIOSVersion": "iOS 17.1 ou superior é necessário para este tipo de transmissão ao vivo.",
+ "livePlayerRequiredIOSVersion": "É necessário o iOS 17.1 ou superior para este tipo de transmissão ao vivo.",
"toast": {
"success": {
- "submittedFrigatePlus": "Quadro enviado com sucesso para o Frigate+"
+ "submittedFrigatePlus": "Imagem submetida com sucesso para Frigate+"
},
"error": {
- "submitFrigatePlusFailed": "Falha ao enviar o quadro para o Frigate+"
+ "submitFrigatePlusFailed": "Não foi possível submeter a imagem para Frigate+"
}
}
}
diff --git a/web/public/locales/pt/objects.json b/web/public/locales/pt/objects.json
index ada61d184..88762a7f3 100644
--- a/web/public/locales/pt/objects.json
+++ b/web/public/locales/pt/objects.json
@@ -2,16 +2,16 @@
"giraffe": "Girafa",
"cup": "Chávena",
"person": "Pessoa",
- "stop_sign": "Sinal de Stop",
+ "stop_sign": "Sinal de Parar",
"sheep": "Ovelha",
- "sandwich": "Sandes",
+ "sandwich": "Sande",
"carrot": "Cenoura",
- "dining_table": "Mesa de jantar",
- "motorcycle": "Motociclo",
+ "dining_table": "Mesa de Jantar",
+ "motorcycle": "Mota",
"bicycle": "Bicicleta",
- "street_sign": "Sinal de rua",
+ "street_sign": "Sinal de Rua",
"pizza": "Pizza",
- "parking_meter": "Parquímetro",
+ "parking_meter": "Parcómetro",
"skateboard": "Skate",
"bottle": "Garrafa",
"car": "Carro",
@@ -23,19 +23,19 @@
"fire_hydrant": "Boca de Incêndio",
"bird": "Pássaro",
"cat": "Gato",
- "bench": "Banco de jardim/rua",
+ "bench": "Banco de Jardim",
"elephant": "Elefante",
"hat": "Chapéu",
"backpack": "Mochila",
"shoe": "Sapato",
- "handbag": "Bolsa de mão",
+ "handbag": "Carteira",
"tie": "Gravata",
- "suitcase": "Mala de viagem",
+ "suitcase": "Mala de Viagem",
"frisbee": "Disco de Frisbee",
"skis": "Esquis",
- "kite": "Kite",
- "baseball_bat": "Taco basebol",
- "tennis_racket": "Raquete de Tenis",
+ "kite": "Papagaio de Papel",
+ "baseball_bat": "Taco de Basebol",
+ "tennis_racket": "Raquete de Ténis",
"plate": "Prato",
"wine_glass": "Copo de Vinho",
"fork": "Garfo",
@@ -43,17 +43,17 @@
"bowl": "Tijela",
"banana": "Banana",
"apple": "Maça",
- "hot_dog": "Cachorro quente",
+ "hot_dog": "Cachorro Quente",
"donut": "Donut",
"cake": "Bolo",
"chair": "Cadeira",
- "potted_plant": "Planta em vaso",
+ "potted_plant": "Planta em Vaso",
"mirror": "Espelho",
- "desk": "Mesa",
+ "desk": "Escrivaninha",
"toilet": "Casa de Banho",
"door": "Porta",
- "baseball_glove": "Luva de beisebol",
- "surfboard": "Prancha de surf",
+ "baseball_glove": "Luva de Basebol",
+ "surfboard": "Prancha de Surf",
"broccoli": "Brócolos",
"snowboard": "Snowboard",
"dog": "Cão",
@@ -74,22 +74,22 @@
"bark": "Latido",
"goat": "Cabra",
"vehicle": "Veículo",
- "scissors": "Tesoura",
+ "scissors": "Tesouras",
"mouse": "Rato",
- "teddy_bear": "Urso de peluche",
- "hair_dryer": "Secador de cabelo",
- "toothbrush": "Escova de dentes",
+ "teddy_bear": "Urso de Peluche",
+ "hair_dryer": "Secador de Cabelo",
+ "toothbrush": "Escova de Dentes",
"hair_brush": "Escova de Cabelo",
"squirrel": "Esquilo",
"couch": "Sofá",
"tv": "TV",
"laptop": "Portátil",
- "remote": "Controlo Remoto",
+ "remote": "Comando",
"cell_phone": "Telemóvel",
"microwave": "Microondas",
"oven": "Forno",
"toaster": "Torradeira",
- "sink": "Pia",
+ "sink": "Banca",
"refrigerator": "Frigorífico",
"blender": "Liquidificador",
"book": "Livro",
@@ -98,7 +98,7 @@
"fox": "Raposa",
"rabbit": "Coelho",
"raccoon": "Guaxinim",
- "robot_lawnmower": "Robô corta relva",
+ "robot_lawnmower": "Robô de Cortar Relva",
"waste_bin": "Contentor do Lixo",
"on_demand": "On Demand",
"face": "Rosto",
diff --git a/web/public/locales/pt/views/classificationModel.json b/web/public/locales/pt/views/classificationModel.json
new file mode 100644
index 000000000..2bd713a09
--- /dev/null
+++ b/web/public/locales/pt/views/classificationModel.json
@@ -0,0 +1,51 @@
+{
+ "button": {
+ "trainModel": "Treinar Modelo",
+ "addClassification": "Adicionar Classificação",
+ "deleteModels": "Apagar Modelos",
+ "editModel": "Editar Modelo",
+ "deleteClassificationAttempts": "Excluir imagens de classificação",
+ "renameCategory": "Renomear Classe",
+ "deleteCategory": "Excluir Classe",
+ "deleteImages": "Excluir imagens"
+ },
+ "tooltip": {
+ "trainingInProgress": "Modelo está a ser treinado",
+ "noNewImages": "Não há novas imagens para treinar. Classifique mais imagens no dataset.",
+ "noChanges": "Nenhuma alteração foi feita no conjunto de dados desde o último treinamento.",
+ "modelNotReady": "O modelo não está pronto para treinamento"
+ },
+ "details": {
+ "scoreInfo": "A pontuação representa a confiança média da classificação em todas as detecções deste objeto.",
+ "none": "Nenhum",
+ "unknown": "Desconhecido"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Classe excluída",
+ "deletedImage": "Imagens excluídas",
+ "categorizedImage": "Imagem classificada com sucesso",
+ "trainedModel": "Modelo treinado com sucesso.",
+ "trainingModel": "Treinamento do modelo iniciado com sucesso.",
+ "updatedModel": "Configuração do modelo atualizada com sucesso",
+ "renamedCategory": "Classe renomeada com sucesso para {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Falha ao excluir: {{errorMessage}}",
+ "deleteCategoryFailed": "Falha ao excluir a classe: {{errorMessage}}",
+ "deleteModelFailed": "Falha ao excluir o modelo: {{errorMessage}}",
+ "categorizeFailed": "Falha ao categorizar a imagem: {{errorMessage}}",
+ "trainingFailed": "O treinamento do modelo falhou. Verifique os registros do Frigate para obter detalhes.",
+ "trainingFailedToStart": "Falha ao iniciar o treinamento do modelo: {{errorMessage}}",
+ "updateModelFailed": "Falha ao atualizar o modelo: {{errorMessage}}",
+ "renameCategoryFailed": "Falha ao renomear a classe: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Excluir Classe",
+ "desc": "Tem certeza de que deseja excluir a classe {{name}}? Isso excluirá permanentemente todas as imagens associadas e exigirá o treinamento do modelo novamente.",
+ "minClassesTitle": "Não é possível excluir a classe",
+ "minClassesDesc": "Um modelo de classificação deve ter pelo menos duas classes. Adicione outra classe antes de excluir esta."
+ },
+ "documentTitle": "Modelos de Classificação – Frigate"
+}
diff --git a/web/public/locales/pt/views/configEditor.json b/web/public/locales/pt/views/configEditor.json
index 6d6c98166..fb1d3377a 100644
--- a/web/public/locales/pt/views/configEditor.json
+++ b/web/public/locales/pt/views/configEditor.json
@@ -1,16 +1,18 @@
{
- "configEditor": "Editor de configuração",
- "copyConfig": "Copiar configuração",
- "saveAndRestart": "Salvar e reiniciar",
- "saveOnly": "Salvar Apenas",
+ "configEditor": "Editor de Configuração",
+ "copyConfig": "Copiar Configuração",
+ "saveAndRestart": "Guardar e Reiniciar",
+ "saveOnly": "Guardar Apenas",
"toast": {
"success": {
"copyToClipboard": "Configuração copiada para a área de transferência."
},
"error": {
- "savingError": "Erro ao salvar configuração"
+ "savingError": "Erro ao guardar a configuração"
}
},
- "documentTitle": "Editor de configuração - Frigate",
- "confirm": "Sair sem salvar?"
+ "documentTitle": "Frigate - Editor de Configuração",
+ "confirm": "Sair sem guardar?",
+ "safeConfigEditor": "Editor de Configuração (Modo de Segurança)",
+ "safeModeDescription": "O Frigate está no modo de segurança devido a um erro de validação da configuração."
}
diff --git a/web/public/locales/pt/views/events.json b/web/public/locales/pt/views/events.json
index 6478001c6..bb9b2e0ff 100644
--- a/web/public/locales/pt/views/events.json
+++ b/web/public/locales/pt/views/events.json
@@ -1,10 +1,10 @@
{
- "detections": "Detecções",
+ "detections": "Deteções",
"motion": {
"label": "Movimento",
- "only": "Somente movimento"
+ "only": "Apenas movimento"
},
- "allCameras": "Todas as câmaras",
+ "allCameras": "Todas as Câmaras",
"empty": {
"motion": "Nenhum dado de movimento encontrado",
"alert": "Não há alertas para análise",
@@ -20,7 +20,7 @@
"alerts": "Alertas",
"documentTitle": "Análise - Frigate",
"recordings": {
- "documentTitle": "Gravações - Frigate"
+ "documentTitle": "Frigate - Gravações"
},
"calendarFilter": {
"last24Hours": "Últimas 24 horas"
@@ -32,7 +32,9 @@
"button": "Novos itens para analisar"
},
"camera": "Câmara",
- "detected": "detectado",
+ "detected": "detetado",
"selected_one": "{{count}} selecionado",
- "selected_other": "{{count}} selecionados"
+ "selected_other": "{{count}} selecionados",
+ "suspiciousActivity": "Atividade Suspeita",
+ "threateningActivity": "Atividade Ameaçadora"
}
diff --git a/web/public/locales/pt/views/explore.json b/web/public/locales/pt/views/explore.json
index a271d1df7..721508174 100644
--- a/web/public/locales/pt/views/explore.json
+++ b/web/public/locales/pt/views/explore.json
@@ -2,7 +2,7 @@
"generativeAI": "IA Generativa",
"exploreIsUnavailable": {
"embeddingsReindexing": {
- "startingUp": "Iniciando…",
+ "startingUp": "A iniciar…",
"estimatedTime": "Tempo restante estimado:",
"finishingShortly": "Terminando em breve",
"step": {
@@ -17,14 +17,14 @@
"visionModel": "Modelo de visão",
"textModel": "Modelo de texto",
"textTokenizer": "Tokenizador de texto",
- "visionModelFeatureExtractor": "Extrator de características de modelo de visão"
+ "visionModelFeatureExtractor": "Extrator de funcionalidade de modelo de visão"
},
- "context": "O Frigate está descarregando os modelos de incorporação necessários para dar suporte a funcionalidade de pesquisa semântica. Isso pode levar vários minutos, dependendo da velocidade da sua conexão de rede.",
+ "context": "O Frigate está a transferir os modelos de incorporação necessários para suportar a funcionalidade de \"Procura Semântica\". Isto pode levar vários minutos, dependendo da velocidade da sua ligação de rede.",
"tips": {
- "context": "Talvez você queira reindexar as incorporações dos seus objetos rastreados depois que os modelos forem descarregados.",
+ "context": "Talvez queira reindexar as incorporações dos seus objetos rastreados depois de os modelos serem transferidos.",
"documentation": "Leia a documentação"
},
- "error": "Ocorreu um erro. Verifique os logs do Frigate."
+ "error": "Ocorreu um erro. Verifique os registos do Frigate."
},
"title": "Explorar não está disponível"
},
@@ -43,12 +43,14 @@
"success": {
"regenerate": "Uma nova descrição foi solicitada pelo {{provider}}. Dependendo da velocidade do seu fornecedor, a nova descrição pode levar algum tempo para ser regenerada.",
"updatedSublabel": "Sub-rotulo atualizado com sucesso.",
- "updatedLPR": "Matrícula atualizada com sucesso."
+ "updatedLPR": "Matrícula atualizada com sucesso.",
+ "audioTranscription": "Transcrição de áudio solicitada com sucesso."
},
"error": {
"regenerate": "Falha ao chamar {{provider}} para uma nova descrição: {{errorMessage}}",
"updatedSublabelFailed": "Falha ao atualizar o sub-rotulo: {{errorMessage}}",
- "updatedLPRFailed": "Falha ao atualizar a matrícula: {{errorMessage}}"
+ "updatedLPRFailed": "Falha ao atualizar a matrícula: {{errorMessage}}",
+ "audioTranscription": "Falha ao solicitar transcrição de áudio: {{errorMessage}}"
}
},
"button": {
@@ -97,27 +99,30 @@
"tips": {
"descriptionSaved": "Descrição salva com sucesso",
"saveDescriptionFailed": "Falha ao atualizar a descrição: {{errorMessage}}"
+ },
+ "score": {
+ "label": "Classificação"
}
},
- "documentTitle": "Explorar - Frigate",
+ "documentTitle": "Frigate - Explorar",
"trackedObjectDetails": "Detalhes do objeto rastreado",
"type": {
"details": "detalhes",
"video": "vídeo",
"object_lifecycle": "ciclo de vida do objeto",
- "snapshot": "snapshot"
+ "snapshot": "captura de ecrã"
},
"objectLifecycle": {
"title": "Ciclo de vida do objeto",
"lifecycleItemDesc": {
"attribute": {
"other": "{{label}} reconhecido como {{attribute}}",
- "faceOrLicense_plate": "{{attribute}} detectado por {{label}}"
+ "faceOrLicense_plate": "{{attribute}} detetado por {{label}}"
},
"gone": "{{label}} saiu",
"heard": "{{label}} ouvido",
"visible": "{{label}} detectado",
- "external": "{{label}} detectado",
+ "external": "{{label}} detetado",
"entered_zone": "{{label}} entrou em {{zones}}",
"active": "{{label}} se tornou ativo",
"stationary": "{{label}} se tornou estacionário",
@@ -128,7 +133,7 @@
}
},
"annotationSettings": {
- "title": "Configurações de anotação",
+ "title": "Definições de Anotação",
"offset": {
"documentation": "Leia a documentação ",
"desc": "Esses dados vêm do feed de detecção da sua câmara, mas são sobrepostos nas imagens do feed de gravação. É improvável que os dois streams estejam perfeitamente sincronizados. Como resultado, a caixa delimitadora e o vídeo não se alinharão perfeitamente. No entanto, o campo annotation_offset pode ser usado para ajustar isso.",
@@ -140,8 +145,8 @@
}
},
"showAllZones": {
- "title": "Mostrar todas as zonas",
- "desc": "Sempre mostrar zonas nos quadros onde os objetos entraram em uma zona."
+ "title": "Mostrar Todas as Zonas",
+ "desc": "Mostrar sempre as zonas nas imagens onde os objetos entraram numa zona."
}
},
"carousel": {
@@ -150,9 +155,9 @@
},
"noImageFound": "Nenhuma imagem encontrada para este carimbo de data/hora.",
"createObjectMask": "Criar Máscara de Objeto",
- "adjustAnnotationSettings": "Ajustar configurações de anotação",
- "autoTrackingTips": "As posições da caixa delimitadora serão imprecisas para câmeras com rastreamento automático.",
- "scrollViewTips": "Faça scroll para ver os momentos significativos do ciclo de vida deste objeto.",
+ "adjustAnnotationSettings": "Ajustar definições de anotação",
+ "autoTrackingTips": "As posições da caixa delimitadora serão imprecisas para as câmaras com rastreamento automático.",
+ "scrollViewTips": "Deslize para ver os momentos significativos do ciclo de vida deste objeto.",
"count": "{{first}} de {{second}}",
"trackedPoint": "Ponto Rastreado"
},
@@ -183,6 +188,14 @@
},
"deleteTrackedObject": {
"label": "Excluir este objeto rastreado"
+ },
+ "addTrigger": {
+ "label": "Adicionar gatilho",
+ "aria": "Adicione um gatilho para este objeto rastreado"
+ },
+ "audioTranscription": {
+ "label": "Transcrever",
+ "aria": "Solicitar transcrição de áudio"
}
},
"searchResult": {
@@ -205,5 +218,11 @@
"trackedObjectsCount_one": "{{count}} objeto rastreado ",
"trackedObjectsCount_many": "{{count}} objetos rastreados ",
"trackedObjectsCount_other": "",
- "exploreMore": "Explora mais objetos {{label}}"
+ "exploreMore": "Explora mais objetos {{label}}",
+ "aiAnalysis": {
+ "title": "Análise IA"
+ },
+ "concerns": {
+ "label": "Preocupações"
+ }
}
diff --git a/web/public/locales/pt/views/exports.json b/web/public/locales/pt/views/exports.json
index f1c441a2e..82f79bd4e 100644
--- a/web/public/locales/pt/views/exports.json
+++ b/web/public/locales/pt/views/exports.json
@@ -13,5 +13,8 @@
"renameExportFailed": "Falha ao renomear exportação: {{errorMessage}}"
}
},
- "deleteExport.desc": "Tem a certeza de que deseja excluir {{exportName}}?"
+ "deleteExport.desc": "Tem a certeza de que deseja excluir {{exportName}}?",
+ "tooltip": {
+ "shareExport": "Partilhar exportação"
+ }
}
diff --git a/web/public/locales/pt/views/faceLibrary.json b/web/public/locales/pt/views/faceLibrary.json
index 057e01569..24e7e14f9 100644
--- a/web/public/locales/pt/views/faceLibrary.json
+++ b/web/public/locales/pt/views/faceLibrary.json
@@ -27,7 +27,7 @@
},
"train": {
"aria": "Selecionar treino",
- "title": "Treinar",
+ "title": "Reconhecimentos Recentes",
"empty": "Não há tentativas recentes de reconhecimento facial"
},
"selectItem": "Selecionar {{item}}",
@@ -55,7 +55,7 @@
"trainFace": "Treinar rosto",
"toast": {
"success": {
- "updatedFaceScore": "Pontuação facial atualizada com sucesso.",
+ "updatedFaceScore": "Pontuação facial atualizada com sucesso para {{name}} ({{score}}).",
"trainedFace": "Rosto treinado com sucesso.",
"deletedFace_one": "{{count}} rosto excluído com sucesso.",
"deletedFace_many": "{{count}} rostos excluídos com sucesso.",
diff --git a/web/public/locales/pt/views/live.json b/web/public/locales/pt/views/live.json
index eb0330a97..770028a85 100644
--- a/web/public/locales/pt/views/live.json
+++ b/web/public/locales/pt/views/live.json
@@ -42,6 +42,14 @@
"center": {
"label": "Clique no quadro para centralizar a câmara PTZ"
}
+ },
+ "focus": {
+ "in": {
+ "label": "Em foco da câmera PTZ"
+ },
+ "out": {
+ "label": "Fora foco da câmera PTZ em"
+ }
}
},
"lowBandwidthMode": "Modo de baixa largura de banda",
@@ -130,7 +138,8 @@
"recording": "Gravando",
"audioDetection": "Detecção de áudio",
"autotracking": "Rastreamento automático",
- "snapshots": "Snapshots"
+ "snapshots": "Snapshots",
+ "transcription": "Transcrição de áudio"
},
"effectiveRetainMode": {
"modes": {
@@ -154,5 +163,9 @@
},
"history": {
"label": "Mostrar filmagens históricas"
+ },
+ "transcription": {
+ "enable": "Habilitar transcrição de áudio ao vivo",
+ "disable": "Desabilitar transcrição de áudio ao vivo"
}
}
diff --git a/web/public/locales/pt/views/settings.json b/web/public/locales/pt/views/settings.json
index f453e6a5b..1bab92d78 100644
--- a/web/public/locales/pt/views/settings.json
+++ b/web/public/locales/pt/views/settings.json
@@ -6,11 +6,13 @@
"motionTuner": "Ajuste de movimento - Frigate",
"object": "Depuração - Frigate",
"authentication": "Configurações de autenticação - Frigate",
- "general": "Configurações Gerais - Frigate",
+ "general": "Configurações gerais - Frigate",
"frigatePlus": "Configurações do Frigate+ - Frigate",
"default": "Configurações - Frigate",
"notifications": "Configuração de Notificações - Frigate",
- "enrichments": "Configurações Avançadas - Frigate"
+ "enrichments": "Configurações Avançadas - Frigate",
+ "cameraManagement": "Gerir Câmaras - Frigate",
+ "cameraReview": "Configurações de Revisão de Câmara - Frigate"
},
"menu": {
"ui": "UI",
@@ -22,7 +24,11 @@
"users": "Utilizadores",
"notifications": "Notificações",
"frigateplus": "Frigate+",
- "enrichments": "Avançado"
+ "enrichments": "Avançado",
+ "triggers": "Gatilhos",
+ "cameraManagement": "Gestão",
+ "cameraReview": "Rever",
+ "roles": "Papéis"
},
"dialog": {
"unsavedChanges": {
@@ -465,6 +471,19 @@
"mask": {
"title": "Máscaras de movimento",
"desc": "Mostrar polígonos de máscara de movimento"
+ },
+ "paths": {
+ "title": "Caminhos",
+ "desc": "Mostrar pontos significativos do caminho do objeto rastreado",
+ "tips": "Paths
Linhas e círculos indicarão pontos significativos que o objeto rastreado moveu durante seu ciclo de vida.
" + }, + "openCameraWebUI": "Abrir a Interface Web de {{camera}}", + "audio": { + "title": "Áudio", + "noAudioDetections": "Nenhuma detecção de áudio", + "score": "pontuanção", + "currentRMS": "RMS Atual", + "currentdbFS": "dbFS Atual" } }, "camera": { @@ -499,6 +518,44 @@ "desc": "Ative ou desative alertas e detecções para esta câmara. Quando desativado, nenhum novo item de análise será gerado. ", "alerts": "Alertas ", "detections": "Detecções " + }, + "object_descriptions": { + "title": "Descrições de objetos de IA generativa", + "desc": "Ative/desative temporariamente as descrições de objetos de IA generativa para esta câmera. Quando desativadas, as descrições geradas por IA não serão solicitadas para objetos rastreados nesta câmera." + }, + "review_descriptions": { + "title": "Descrições de análises de IA generativa", + "desc": "Ative/desative temporariamente as descrições de avaliação geradas por IA para esta câmera. Quando desativadas, as descrições geradas por IA não serão solicitadas para itens de avaliação nesta câmera." + }, + "addCamera": "Adicionar Nova Câmera", + "editCamera": "Editar Câmera:", + "selectCamera": "Selecione uma Câmera", + "backToSettings": "Voltar para as Configurações da Câmera", + "cameraConfig": { + "add": "Adicionar Câmera", + "edit": "Editar Câmera", + "description": "Configure as definições da câmera, incluindo entradas de transmissão e funções.", + "name": "Nome da Câmera", + "nameRequired": "O nome da câmera é obrigatório", + "nameInvalid": "O nome da câmera deve conter apenas letras, números, sublinhados ou hifens", + "namePlaceholder": "e.g., porta_da_frente", + "enabled": "Habilitado", + "ffmpeg": { + "inputs": "Entrada de Streams", + "path": "Caminho da Stream", + "pathRequired": "Caminho da Stream é obrigatória", + "pathPlaceholder": "rtsp://...", + "roles": "Funções", + "rolesRequired": "Pelo menos uma função é necessária", + "rolesUnique": "Cada função (áudio, detecção, gravação) só pode ser atribuída a uma stream", + "addInput": "Adicionar Entrada de Stream", + "removeInput": "Remover Entrada de Stream", + "inputsRequired": "É necessário pelo menos uma stream de entrada" + }, + "toast": { + "success": "Câmera {{cameraName}} guardada com sucesso" + }, + "nameLength": "O nome da câmara deve ter ao menos 24 caracteres." } }, "motionDetectionTuner": { @@ -594,7 +651,8 @@ "adminDesc": "Acesso total a todos os recursos.", "viewer": "Visualização", "viewerDesc": "Limitado apenas a painéis ao vivo, análise, exploração e exportações.", - "intro": "Selecione a função apropriada para este utilizador:" + "intro": "Selecione a função apropriada para este utilizador:", + "customDesc": "Papel customizado com acesso a câmaras específicas." }, "title": "Alterar função do utilizador", "desc": "Atualizar permissões para {{username}}", @@ -682,5 +740,247 @@ "roleUpdateFailed": "Falha ao atualizar a função: {{errorMessage}}" } } + }, + "triggers": { + "documentTitle": "Triggers (gatilhos)", + "management": { + "title": "Gestão de Triggers", + "desc": "Gira triggers para {{camera}}. Use o tipo de miniatura para acionar miniaturas semelhantes ao objeto rastreado selecionado e o tipo de descrição para acionar descrições semelhantes ao texto especificado." + }, + "addTrigger": "Adicionar Trigger", + "table": { + "name": "Nome", + "type": "Tipo", + "content": "Conteúdo", + "threshold": "Limite", + "actions": "Ações", + "noTriggers": "Nenhum trigger configurado para esta câmera.", + "edit": "Editar", + "deleteTrigger": "Apagar Trigger", + "lastTriggered": "Último acionado" + }, + "type": { + "thumbnail": "Miniatura", + "description": "Descrição" + }, + "actions": { + "alert": "Marcar como Alerta", + "notification": "Enviar Notificação" + }, + "dialog": { + "createTrigger": { + "title": "Criar Trigger", + "desc": "Crie um trigger para a câmera {{camera}}" + }, + "editTrigger": { + "title": "Editar Trigger", + "desc": "Editar as definições do trigger na câmera {{camera}}" + }, + "deleteTrigger": { + "title": "Apagar Trigger", + "desc": "Tem certeza de que deseja apagar o trigger {{triggerName}}? Esta ação não pode ser desfeita." + }, + "form": { + "name": { + "title": "Nome", + "placeholder": "Insira o nome do trigger", + "error": { + "minLength": "O nome deve ter pelo menos 2 caracteres.", + "invalidCharacters": "O nome só pode conter letras, números, sublinhados e hifens.", + "alreadyExists": "Já existe um trigger com este nome para esta câmera." + } + }, + "enabled": { + "description": "Habilitar ou desabilitar este trigger" + }, + "type": { + "title": "Tipo", + "placeholder": "Selecione o tipo de trigger" + }, + "content": { + "title": "Conteúdo", + "imagePlaceholder": "Selecione uma imagem", + "textPlaceholder": "Insira o conteúdo do texto", + "imageDesc": "Selecione uma imagem para acionar esta ação quando uma imagem semelhante for detectada.", + "textDesc": "Insira um texto para acionar esta ação quando uma descrição de objeto rastreado semelhante for detectada.", + "error": { + "required": "O Conteúdo é obrigatório." + } + }, + "threshold": { + "title": "Limite", + "error": { + "min": "Limite deve ser pelo menos 0", + "max": "Limite deve ser no máximo 1" + } + }, + "actions": { + "title": "Ações", + "desc": "Por padrão, o Frigate envia uma mensagem MQTT para todos os triggers. Escolha uma ação adicional a ser executada quando este trigger for disparado.", + "error": { + "min": "Pelo menos uma ação deve ser selecionada." + } + }, + "friendly_name": { + "title": "Nome Amigável", + "placeholder": "Nomeie ou descreva este gatilho", + "description": "Um nome amigável ou descritivo opcional para este gatilho." + } + } + }, + "toast": { + "success": { + "createTrigger": "Trigger {{name}} criado com sucesso.", + "updateTrigger": "Trigger {{name}} atualizado com sucesso.", + "deleteTrigger": "Trigger {{name}} apagado com sucesso." + }, + "error": { + "createTriggerFailed": "Falha ao criar trigger: {{errorMessage}}", + "updateTriggerFailed": "Falha ao atualizar o trigger: {{errorMessage}}", + "deleteTriggerFailed": "Falha ao apagar o trigger: {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "Pesquisa Semântica desativada", + "desc": "Pesquisa Semântica deve estar ativada para usar os Gatilhos." + } + }, + "roles": { + "management": { + "title": "Gestão do Papel de Visualizador", + "desc": "Gerir papéis de visualizador customizados e as suas permissões de acesso para esta instância do Frigate." + }, + "addRole": "Adicionar Papel", + "table": { + "role": "Papel", + "cameras": "Câmaras", + "actions": "Ações", + "noRoles": "Nenhum papel customizado encontrado.", + "editCameras": "Editar Câmaras", + "deleteRole": "Apagar Papel" + }, + "toast": { + "success": { + "createRole": "Papel {{role}} criado com sucesso", + "updateCameras": "Câmaras atualizados para o papel {{role}}", + "deleteRole": "Papel {{role}} apagado com sucesso", + "userRolesUpdated_one": "{{count}} utilizador(os) atribuídos a este papel foram atualizados para 'visualizador', que possui acesso a todas as câmaras.", + "userRolesUpdated_many": "", + "userRolesUpdated_other": "" + }, + "error": { + "createRoleFailed": "Falha ao criar papel: {{errorMessage}}", + "updateCamerasFailed": "Falha ao atualizar câmaras: {{errorMessage}}", + "deleteRoleFailed": "Falha ao apagar papel: {{errorMessage}}", + "userUpdateFailed": "Falha ao atualizar papel do utilizador: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Criar Novo Papel", + "desc": "Adicionar um novo papel e especificar permissões de acesso." + }, + "editCameras": { + "title": "Editar Câmaras de Papéis", + "desc": "Atualizar acesso da câmara para o papel {{role}}." + }, + "deleteRole": { + "title": "Apagar Papel", + "desc": "Esta ação não pode ser desfeita. Isto irá apagar permanentemente o papel e atribuir a quaisquer utilizadores com este papel como 'visualizador', o que dará acesso de visualização para todas as câmaras.", + "warn": "Tem certeza que quer apagar {{role}}?", + "deleting": "A apagar…" + }, + "form": { + "role": { + "title": "Nome do Papel", + "placeholder": "Digitar nome do papel", + "desc": "Apenas letras, números, pontos e sublinhados são permitidos.", + "roleIsRequired": "Nome para o papel é requerido", + "roleOnlyInclude": "O nome do papel pode conter apenas letras, números, pontos ou sublinhados", + "roleExists": "Um papel com este nome já existe." + }, + "cameras": { + "title": "Câmaras", + "desc": "Selecione as câmaras que este papel terá acesso. Ao menos uma câmara é requerida.", + "required": "Ao menos uma câmara deve ser selecionada." + } + } + } + }, + "cameraWizard": { + "title": "Adicionar Câmara", + "description": "Siga os passos abaixo para adicionar uma câmara nova no seu Frigate.", + "steps": { + "nameAndConnection": "Nome e Conexão", + "streamConfiguration": "Configuração de Stream", + "validationAndTesting": "Validação e Teste" + }, + "save": { + "success": "Nova câmara {{cameraName}} grava com sucesso.", + "failure": "Erro ao gravar {{cameraName}}." + }, + "testResultLabels": { + "resolution": "Resolução", + "video": "Vídeo", + "audio": "Áudio", + "fps": "FPS" + }, + "commonErrors": { + "noUrl": "Favor fornecer uma URL de stream válida", + "testFailed": "Teste de stream falhou: {{error}}" + }, + "step1": { + "description": "Adicione os pormenores da sua câmara e teste a conexão.", + "cameraName": "Nome da Câmara", + "cameraNamePlaceholder": "ex., porta_entrada ou Visão Geral do Quintal", + "host": "Host/Endereço IP", + "port": "Porta", + "username": "Nome de Utilizador", + "usernamePlaceholder": "Opcional", + "password": "Palavra-passe", + "passwordPlaceholder": "Opcional", + "selectTransport": "Selecionar protocolo de transporte", + "cameraBrand": "Marca da Câmara", + "selectBrand": "Selecione a marca da câmara para template de URL", + "customUrl": "URL Customizada de Stream", + "brandInformation": "Informação da marca", + "brandUrlFormat": "Para câmaras com o formato de URL RTSP como: {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://nomedeusuario:palavra-passe@host:porta/caminho", + "testConnection": "Testar Conexão", + "testSuccess": "Teste de conexão bem sucedido!", + "testFailed": "Teste de conexão falhou. Favor verifique os dados e tente novamente.", + "streamDetails": "Pormenores do Stream", + "warnings": { + "noSnapshot": "Não foi possível adquirir uma captura de imagem do stream configurado." + }, + "errors": { + "brandOrCustomUrlRequired": "Selecione a marca da câmara com o host/IP or selecione 'Outro' com uma URL customizada", + "nameRequired": "Nome para a câmara requerido" + } + }, + "step2": { + "url": "URL", + "roleLabels": { + "audio": "Áudio" + } + }, + "step3": { + "reload": "Recarregar", + "valid": "Válido", + "failed": "Falhou", + "none": "Nenhum", + "error": "Erro" + } + }, + "cameraManagement": { + "cameraConfig": { + "enabled": "Ativado", + "addUrl": "Adicionar URL" + } + }, + "cameraReview": { + "review": { + "title": "Rever" + } } } diff --git a/web/public/locales/pt/views/system.json b/web/public/locales/pt/views/system.json index 2826a9dd9..9f90073c9 100644 --- a/web/public/locales/pt/views/system.json +++ b/web/public/locales/pt/views/system.json @@ -1,14 +1,14 @@ { "documentTitle": { - "storage": "Estatísticas de armazenamento - Frigate", - "general": "Estatísticas gerais - Frigate", - "enrichments": "Estatísticas de enriquecimento - Frigate", + "storage": "Frigate - Estatísticas de Armazenamento", + "general": "Frigate - Estatísticas Gerais", + "enrichments": "Frigate - Estatísticas de Enriquecimento", "logs": { - "frigate": "Logs do Frigate - Frigate", - "go2rtc": "Logs do Go2RTC - Frigate", - "nginx": "Logs do Nginx - Frigate" + "frigate": "Frigate - Registos de Eventos do Frigate", + "go2rtc": "Frigate - Registos de Eventos do Go2RTC", + "nginx": "Frigate - Registos de Eventos do Nginx" }, - "cameras": "Estatísticas das câmaras - Frigate" + "cameras": "Frigate - Estatísticas das Câmaras" }, "title": "Sistema", "metrics": "Métricas do sistema", @@ -16,22 +16,22 @@ "type": { "label": "Tipo", "timestamp": "Carimbo de hora", - "tag": "Tag", + "tag": "Etiqueta", "message": "Mensagem" }, "copy": { - "success": "Logs copiados para a área de transferência", - "label": "Copiar para a área de transferência", - "error": "Não foi possível copiar os logs para a área de transferência" + "success": "Registos copiados para a área de transferência", + "label": "Copiar para a Área de Transferência", + "error": "Não foi possível copiar os registos para a área de transferência" }, "download": { - "label": "Descarregar logs" + "label": "Transferir Registos" }, - "tips": "Os logs estão a ser transmitidos do servidor", + "tips": "Os registos estão a ser transmitidos do servidor", "toast": { "error": { - "fetchingLogsFailed": "Erro ao buscar logs: {{errorMessage}}", - "whileStreamingLogs": "Erro ao transmitir logs: {{errorMessage}}" + "fetchingLogsFailed": "Erro ao obter os registos: {{errorMessage}}", + "whileStreamingLogs": "Erro enquanto transmitia os registos: {{errorMessage}}" } } }, @@ -49,11 +49,15 @@ "title": "Armazenamento da câmara" }, "title": "Armazenamento", - "overview": "Visão geral", + "overview": "Sinopse", "recordings": { "title": "Gravações", "earliestRecording": "Primeira gravação disponível:", - "tips": "Esse valor representa o armazenamento total usado pelas gravações na base de dados do Frigate. O Frigate não acompanha o uso de armazenamento de todos os ficheiros no seu disco." + "tips": "Este valor representa o armazenamento total utilizado pelas gravações na base de dados do Frigate. O Frigate não acompanha a utilização do armazenamento de todos os ficheiros no seu disco." + }, + "shm": { + "title": "Alocação SHM (memória partilhada)", + "warning": "A tamanho atual de SHM de {{total}} MB é muito pequeno. Aumente-o para pelo menos {{min_shm}} MB." } }, "cameras": { @@ -83,19 +87,19 @@ "skipped": "ignorado", "ffmpeg": "FFmpeg", "cameraFfmpeg": "{{camName}} FFmpeg", - "cameraFramesPerSecond": "quadros por segundo de {{camName}}", + "cameraFramesPerSecond": "imagens por segundo de {{camName}}", "cameraCapture": "captura de {{camName}}", - "cameraDetectionsPerSecond": "detecções por segundo de {{camName}}", - "overallFramesPerSecond": "quadros por segundo totais (FPS)", - "overallDetectionsPerSecond": "detecções por segundo totais", - "overallSkippedDetectionsPerSecond": "detecções ignoradas por segundo totais", - "cameraDetect": "detecção de {{camName}}", - "cameraSkippedDetectionsPerSecond": "detecções ignoradas por segundo de {{camName}}" + "cameraDetectionsPerSecond": "deteções por segundo de {{camName}}", + "overallFramesPerSecond": "imagens por segundo totais (FPS)", + "overallDetectionsPerSecond": "deteções por segundo totais", + "overallSkippedDetectionsPerSecond": "deteções ignoradas por segundo totais", + "cameraDetect": "deteção de {{camName}}", + "cameraSkippedDetectionsPerSecond": "deteções ignoradas por segundo de {{camName}}" }, "overview": "Visão geral", "toast": { "success": { - "copyToClipboard": "Dados de Exploração copiados para a área de transferência." + "copyToClipboard": "Dados de exploração copiados para a área de transferência." }, "error": { "unableToProbeCamera": "Não foi possível explorar a câmara: {{errorMessage}}" @@ -104,43 +108,45 @@ }, "lastRefreshed": "Última atualização: ", "stats": { - "ffmpegHighCpuUsage": "{{camera}} tem alto uso de CPU FFmpeg ({{ffmpegAvg}}%)", - "detectHighCpuUsage": "{{camera}} tem alto uso de CPU de detecção ({{detectAvg}}%)", + "ffmpegHighCpuUsage": "{{camera}} tem alta utilização da CPU FFmpeg ({{ffmpegAvg}}%)", + "detectHighCpuUsage": "{{camera}} tem alta utilização da CPU de deteção ({{detectAvg}}%)", "healthy": "O sistema está saudável", "reindexingEmbeddings": "Reindexando incorporações ({{processed}}% completo)", "detectIsVerySlow": "{{detect}} está muito lento ({{speed}} ms)", - "cameraIsOffline": "{{camera}} está offline", - "detectIsSlow": "{{detect}} está lento ({{speed}} ms)" + "cameraIsOffline": "{{camera}} está off-line", + "detectIsSlow": "{{detect}} está lento ({{speed}} ms)", + "shmTooLow": "/dev/shm alocação ({{total}} MB) deveria ser aumentada pelo menos {{min}} MB." }, "general": { "title": "Geral", "detector": { - "title": "Detectores", - "cpuUsage": "Utilização do CPU do Detector", - "memoryUsage": "Utilização da memória do Detector", - "inferenceSpeed": "Velocidade de Inferência do Detector", - "temperature": "Temperatura do Detector" + "title": "Detetores", + "cpuUsage": "Utilização do CPU do Detetor", + "memoryUsage": "Utilização da Memória do Detetor", + "inferenceSpeed": "Velocidade de Inferência do Detetor", + "temperature": "Temperatura do Detetor", + "cpuUsageInformation": "CPU utilizada na preparação de dados de entrada e saída de/para os modelos de deteção. Este valor não mede oa utilização da inferência, mesmo se estiver a utilizar uma GPU ou acelerador." }, "hardwareInfo": { - "title": "Informações de hardware", - "gpuUsage": "Utilização GPU", - "gpuMemory": "Memória GPU", + "title": "Informação de Hardware", + "gpuUsage": "Utilização da GPU", + "gpuMemory": "Memória da GPU", "gpuInfo": { "nvidiaSMIOutput": { - "driver": "Driver: {{driver}}", + "driver": "Controlador: {{driver}}", "vbios": "Informação VBios: {{vbios}}", "name": "Nome: {{name}}", "cudaComputerCapability": "Capacidade de computação CUDA: {{cuda_compute}}", "title": "Saída Nvidia SMI" }, "copyInfo": { - "label": "Copiar informações do GPU" + "label": "Copiar informação da GPU" }, "closeInfo": { - "label": "Fechar informações do GPU" + "label": "Fechar informação da GPU" }, "toast": { - "success": "Informações do GPU copiadas para a área de transferência" + "success": "Informação da GPU copiada para a área de transferência" }, "vainfoOutput": { "title": "Saída do Vainfo", @@ -149,32 +155,32 @@ "processError": "Erro no processo:" } }, - "gpuEncoder": "GPU Encoder", - "gpuDecoder": "GPU Decoder", + "gpuEncoder": "Codificador da GPU", + "gpuDecoder": "Descodificador da GPU", "npuUsage": "Utilização NPU", "npuMemory": "Memória NPU" }, "otherProcesses": { - "title": "Outros processos", - "processCpuUsage": "Uso de CPU do processo", - "processMemoryUsage": "Uso de memória do processo" + "title": "Outros Processos", + "processCpuUsage": "Utilização da CPU do Processo", + "processMemoryUsage": "Utilização da Memória do Processo" } }, "enrichments": { "title": "Enriquecimentos", - "infPerSecond": "Inferências por segundo", + "infPerSecond": "Inferências por Segundo", "embeddings": { - "image_embedding_speed": "Velocidade de incorporação de imagem", - "face_embedding_speed": "Velocidade de incorporação facial", - "plate_recognition_speed": "Velocidade de reconhecimento de placas", - "text_embedding_speed": "Velocidade de incorporação de texto", + "image_embedding_speed": "Velocidade de Incorporação de Imagem", + "face_embedding_speed": "Velocidade de Incorporação Facial", + "plate_recognition_speed": "Velocidade de Reconhecimento de Placas", + "text_embedding_speed": "Velocidade de Incorporação de Texto", "face_recognition_speed": "Velocidade de Reconhecimento Facial", "plate_recognition": "Reconhecimento de Placas", "image_embedding": "Incorporação de Imagem", "text_embedding": "Incorporação de Texto", "face_recognition": "Reconhecimento Facial", - "yolov9_plate_detection_speed": "Velocidade de Detecção de Placas YOLOv9", - "yolov9_plate_detection": "Detecção de Placas YOLOv9" + "yolov9_plate_detection_speed": "Velocidade de Deteção de Placas YOLOv9", + "yolov9_plate_detection": "Deteção de Placas YOLOv9" } } } diff --git a/web/public/locales/ro/audio.json b/web/public/locales/ro/audio.json index 8221339db..56815c618 100644 --- a/web/public/locales/ro/audio.json +++ b/web/public/locales/ro/audio.json @@ -425,5 +425,79 @@ "single-lens_reflex_camera": "Cameră reflex cu un singur obiectiv", "fusillade": "descărcare de focuri", "pink_noise": "Zgomot roz", - "field_recording": "Înregistrare pe teren" + "field_recording": "Înregistrare pe teren", + "sodeling": "*Sodeling*", + "chird": "*Chird*", + "change_ringing": "Schimbă soneria", + "shofar": "Șofar", + "liquid": "Lichid", + "splash": "Stropire", + "slosh": "Sloș", + "squish": "Plescăit", + "drip": "Picur", + "pour": "Toarnă", + "trickle": "Picurare", + "gush": "Șuvoi", + "fill": "Umplere", + "spray": "Pulverizare", + "pump": "Pompă", + "stir": "Amestecare", + "boiling": "Fierbere", + "sonar": "Sonar", + "arrow": "Săgeată", + "whoosh": "Whoosh", + "thump": "Bufnitură", + "thunk": "Buft", + "electronic_tuner": "Tuner electronic", + "effects_unit": "Efect de unitate", + "chorus_effect": "Efect de cor", + "basketball_bounce": "Săritură minge basket", + "bang": "Bubuitură", + "slap": "Pălmuială", + "whack": "Lovitură", + "smash": "Zdrobitură", + "breaking": "Rupere", + "bouncing": "Saritură", + "whip": "Bici", + "flap": "fâlfâit", + "scratch": "Zgâriat", + "scrape": "Răzuire", + "rub": "Frecare", + "roll": "Rostogolire", + "crushing": "Spargere", + "crumpling": "Șifonare", + "tearing": "Sfâșiere", + "beep": "Bip", + "ping": "Ping", + "ding": "Ding", + "clang": "zăngănit", + "squeal": "Țipăt", + "creak": "Scârțâit", + "rustle": "Foșnet", + "whir": "Vuiet", + "clatter": "Zdrăngăneală", + "sizzle": "Sfârâit", + "clicking": "Clănțănit", + "clickety_clack": "Clănțăneală", + "rumble": "Bubuit", + "plop": "Plop", + "hum": "murmur", + "zing": "Zing", + "boing": "Boing", + "crunch": "ronţăire", + "sine_wave": "Unda Sinusoidală", + "harmonic": "Armonic", + "chirp_tone": "ton de ciripit", + "pulse": "Puls", + "inside": "În interior", + "outside": "Afară", + "reverberation": "Reverberație", + "echo": "Ecou", + "noise": "Gălăgie", + "mains_hum": "Zumzet principal", + "distortion": "Distorsionare", + "sidetone": "Ton lateral", + "cacophony": "Cacofonie", + "throbbing": "Trepidant", + "vibration": "Vibrație" } diff --git a/web/public/locales/ro/common.json b/web/public/locales/ro/common.json index 145d511a4..1148d60c8 100644 --- a/web/public/locales/ro/common.json +++ b/web/public/locales/ro/common.json @@ -1,8 +1,8 @@ { "time": { "untilForTime": "Până la {{time}}", - "untilForRestart": "Pana la repornirea Frigate.", - "untilRestart": "Pana la repornire", + "untilForRestart": "Până la repornirea Frigate.", + "untilRestart": "Până la repornire", "ago": "{{timeAgo}} în urmă", "justNow": "Acum", "today": "Astăzi", @@ -42,7 +42,7 @@ "24hour": "dd-MM-yy-HH-mm-ss" }, "30minutes": "30 de minute", - "1hour": "O oră", + "1hour": "1 oră", "12hours": "12 ore", "24hours": "24 de ore", "pm": "PM", @@ -78,7 +78,11 @@ "minute_other": "{{time}} de minute", "second_one": "{{time}} secundă", "second_few": "{{time}} secunde", - "second_other": "{{time}} de secunde" + "second_other": "{{time}} de secunde", + "inProgress": "În desfășurare", + "invalidStartTime": "Oră de început invalidă", + "invalidEndTime": "Oră de sfârșit invalidă", + "never": "Niciodată" }, "menu": { "documentation": { @@ -123,7 +127,16 @@ "ro": "Română (Română)", "hu": "Magyar (Maghiară)", "fi": "Suomi (Finlandeză)", - "th": "ไทย (Thailandeză)" + "th": "ไทย (Thailandeză)", + "ptBR": "Português brasileiro (Portugheză braziliană)", + "sr": "Српски (Sârbă)", + "sl": "Slovenščina (Slovenă)", + "lt": "Lietuvių (Lituaniană)", + "bg": "Български (Bulgară)", + "gl": "Galego (Galiciană)", + "id": "Bahasa Indonesia (Indoneziană)", + "ur": "اردو (Urdu)", + "hr": "Hrvatski (Croată)" }, "theme": { "default": "Implicit", @@ -171,7 +184,8 @@ }, "withSystem": "Modul sistemului", "restart": "Repornește Frigate", - "review": "Revizuire" + "review": "Revizuire", + "classification": "Clasificare" }, "button": { "cameraAudio": "Sunet cameră", @@ -208,7 +222,8 @@ "unselect": "Deselectează", "export": "Exportă", "deleteNow": "Șterge acum", - "next": "Următorul" + "next": "Următorul", + "continue": "Continuă" }, "unit": { "speed": { @@ -218,10 +233,24 @@ "length": { "feet": "picioare", "meters": "metri" + }, + "data": { + "kbps": "kB/s", + "mbps": "MB/s", + "gbps": "GB/s", + "kbph": "kB/oră", + "mbph": "MB/oră", + "gbph": "GB/oră" } }, "label": { - "back": "Mergi înapoi" + "back": "Mergi înapoi", + "hide": "Ascunde {{item}}", + "show": "Afișează {{item}}", + "ID": "ID", + "none": "Niciuna", + "all": "Toate", + "other": "Altele" }, "selectItem": "Selectează {{item}}", "pagination": { @@ -261,5 +290,18 @@ "documentTitle": "Nu a fost găsit - Frigate", "title": "404", "desc": "Pagină negăsită" + }, + "readTheDocumentation": "Citește documentația", + "information": { + "pixels": "{{area}}px" + }, + "list": { + "two": "{{0}} și {{1}}", + "many": "{{items}}, și {{last}}", + "separatorWithSpace": ", " + }, + "field": { + "optional": "Opțional", + "internalID": "ID-ul Intern pe care Frigate îl folosește în configurație și în baza de date" } } diff --git a/web/public/locales/ro/components/auth.json b/web/public/locales/ro/components/auth.json index 4fa303853..cc3b5923b 100644 --- a/web/public/locales/ro/components/auth.json +++ b/web/public/locales/ro/components/auth.json @@ -10,6 +10,7 @@ "webUnknownError": "Eroare necunoscuta. Verifica logurile din consola.", "usernameRequired": "Utilizatorul este necesar", "unknownError": "Eroare necunoscuta. Verifica logurile." - } + }, + "firstTimeLogin": "Încercați să vă conectați pentru prima dată? Datele de autentificare sunt tipărite în jurnalele Frigate." } } diff --git a/web/public/locales/ro/components/camera.json b/web/public/locales/ro/components/camera.json index d93a81dcc..55396367d 100644 --- a/web/public/locales/ro/components/camera.json +++ b/web/public/locales/ro/components/camera.json @@ -66,7 +66,8 @@ "label": "Mod compatibilitate", "desc": "Activează această opțiune doar dacă stream-ul live al camerei afișează artefacte de culoare și are o linie diagonală pe partea dreaptă a imaginii." } - } + }, + "birdseye": "Vedere de ansamblu" } }, "debug": { diff --git a/web/public/locales/ro/components/dialog.json b/web/public/locales/ro/components/dialog.json index c07b2cee0..cbbbf7115 100644 --- a/web/public/locales/ro/components/dialog.json +++ b/web/public/locales/ro/components/dialog.json @@ -46,7 +46,8 @@ "button": { "deleteNow": "Șterge acum", "export": "Exportă", - "markAsReviewed": "Marchează ca revizuit" + "markAsReviewed": "Marchează ca revizuit", + "markAsUnreviewed": "Marchează ca nerevizuit" }, "confirmDelete": { "toast": { @@ -82,12 +83,13 @@ "export": "Exportă", "selectOrExport": "Selectează sau exportă", "toast": { - "success": "Exportul a început cu succes. Vizualizați fișierul în dosarul /exports.", + "success": "Exportul a început cu succes. Vizualizați fișierul pe pagina de exporturi.", "error": { "failed": "Eroare la pornirea exportului: {{error}}", "endTimeMustAfterStartTime": "Ora de sfârșit trebuie să fie după ora de început", "noVaildTimeSelected": "Nu a fost selectat un interval de timp valid" - } + }, + "view": "Vizualizează" }, "fromTimeline": { "saveExport": "Salvează exportul", @@ -105,7 +107,7 @@ }, "showStats": { "label": "Afișează statistici streaming", - "desc": "Activează această opțiune pentru a afișa statisticile de streaming ca un overlay peste fluxul camerei." + "desc": "Activează această opțiune pentru a afișa statisticile de streaming ca un overlay peste stream-ul camerei." }, "debugView": "Vizualizator depanare" }, @@ -122,5 +124,13 @@ } } } + }, + "imagePicker": { + "selectImage": "Selectează miniatura unui obiect urmărit", + "search": { + "placeholder": "Caută după etichetă sau subetichetă..." + }, + "noImages": "Nu s-au găsit miniaturi pentru această cameră", + "unknownLabel": "Imaginea declanșator salvată" } } diff --git a/web/public/locales/ro/components/filter.json b/web/public/locales/ro/components/filter.json index 40c0c593c..74a65aa62 100644 --- a/web/public/locales/ro/components/filter.json +++ b/web/public/locales/ro/components/filter.json @@ -121,6 +121,20 @@ "selectPlatesFromList": "Selectează una sau mai multe plăcuțe din listă.", "loading": "Se încarcă numerele de înmatriculare recunoscute…", "placeholder": "Caută plăcuțe de înmatriculare…", - "loadFailed": "Nu s-au putut încărca numerele de înmatriculare recunoscute." + "loadFailed": "Nu s-au putut încărca numerele de înmatriculare recunoscute.", + "selectAll": "Selectează tot", + "clearAll": "Elimină tot" + }, + "classes": { + "label": "Clase", + "all": { + "title": "Toate clasele" + }, + "count_one": "{{count}} Clasă", + "count_other": "{{count}} Clase" + }, + "attributes": { + "label": "Atribute de clasificare", + "all": "Toate atributele" } } diff --git a/web/public/locales/ro/views/classificationModel.json b/web/public/locales/ro/views/classificationModel.json new file mode 100644 index 000000000..1ecc6018e --- /dev/null +++ b/web/public/locales/ro/views/classificationModel.json @@ -0,0 +1,193 @@ +{ + "documentTitle": "Modele de clasificare - Frigate", + "button": { + "deleteClassificationAttempts": "Șterge imaginile de clasificare", + "renameCategory": "Redenumește clasa", + "deleteCategory": "Șterge clasa", + "deleteImages": "Șterge imaginile", + "trainModel": "Antrenează modelul", + "addClassification": "Adaugă clasificare", + "deleteModels": "Șterge modelele", + "editModel": "Editează modelul" + }, + "toast": { + "success": { + "deletedCategory": "Clasă ștearsă", + "deletedImage": "Imagini șterse", + "categorizedImage": "Imagine clasificată cu succes", + "trainedModel": "Model antrenat cu succes.", + "trainingModel": "Antrenamentul modelului a fost pornit cu succes.", + "deletedModel_one": "{{count}} model șters cu succes", + "deletedModel_few": "{{count}} modele șterse cu succes", + "deletedModel_other": "{{count}} modele șterse cu succes", + "updatedModel": "Configurația modelului a fost actualizată cu succes", + "renamedCategory": "Clasa a fost redenumită cu succes în {{name}}" + }, + "error": { + "deleteImageFailed": "Ștergerea a eșuat: {{errorMessage}}", + "deleteCategoryFailed": "Ștergerea clasei a eșuat: {{errorMessage}}", + "categorizeFailed": "Categorisirea imaginii a eșuat: {{errorMessage}}", + "trainingFailed": "Antrenarea modelului a eșuat. Verifică jurnalele Frigate pentru detalii.", + "deleteModelFailed": "Ștergerea modelului a eșuat: {{errorMessage}}", + "updateModelFailed": "Actualizarea modelului a eșuat: {{errorMessage}}", + "renameCategoryFailed": "Redenumirea clasei a eșuat: {{errorMessage}}", + "trainingFailedToStart": "Nu s-a putut porni antrenarea modelului: {{errorMessage}}" + } + }, + "deleteCategory": { + "title": "Șterge clasa", + "desc": "Sigur doriți să ștergeți clasa {{name}}? Aceasta va șterge permanent toate imaginile asociate și va necesita reantrenarea modelului.", + "minClassesTitle": "Nu se poate șterge clasa", + "minClassesDesc": "Un model de clasificare trebuie să aibă cel puțin 2 clase. Adaugă o altă clasă înainte de a o șterge pe aceasta." + }, + "deleteDatasetImages": { + "title": "Șterge imaginile setului de date", + "desc_one": "Sigur doriți să ștergeți {{count}} imagine din {{dataset}}? Această acțiune nu poate fi anulată și va necesita reantrenarea modelului.", + "desc_few": "Sigur doriți să ștergeți {{count}} imagini din {{dataset}}? Această acțiune nu poate fi anulată și va necesita reantrenarea modelului.", + "desc_other": "Sigur doriți să ștergeți {{count}} de imagini din {{dataset}}? Această acțiune nu poate fi anulată și va necesita reantrenarea modelului." + }, + "deleteTrainImages": { + "title": "Șterge imaginile de antrenament", + "desc_one": "Sigur doriți să ștergeți {{count}} imagine? Această acțiune nu poate fi anulată.", + "desc_few": "Sigur doriți să ștergeți {{count}} imagini? Această acțiune nu poate fi anulată.", + "desc_other": "Sigur doriți să ștergeți {{count}} de imagini? Această acțiune nu poate fi anulată." + }, + "renameCategory": { + "title": "Redenumește clasa", + "desc": "Introduceți un nume nou pentru {{name}}. Va trebui să reantrenați modelul pentru ca modificarea numelui să aibă efect." + }, + "description": { + "invalidName": "Nume invalid. Numele pot include doar litere, cifre, spații, apostrofuri, underscore-uri și liniuțe." + }, + "train": { + "title": "Clasificări recente", + "titleShort": "Recent", + "aria": "Selectează clasificările recente" + }, + "categories": "Clase", + "createCategory": { + "new": "Creează clasă nouă" + }, + "categorizeImageAs": "Clasifică imaginea ca:", + "categorizeImage": "Clasifică imaginea", + "noModels": { + "object": { + "title": "Nu există modele de clasificare a obiectelor", + "description": "Creează un model personalizat pentru a clasifica obiectele detectate.", + "buttonText": "Creează model de obiect" + }, + "state": { + "title": "Nu există modele de clasificare a stării", + "description": "Creează un model personalizat pentru a monitoriza și clasifica schimbările de stare în anumite zone ale camerei.", + "buttonText": "Creează model de stare" + } + }, + "wizard": { + "title": "Creează clasificare nouă", + "steps": { + "nameAndDefine": "Numire și definire", + "stateArea": "Zona de stare", + "chooseExamples": "Alege exemple" + }, + "step1": { + "description": "Modelele de stare monitorizează zone fixe ale camerei pentru schimbări (de exemplu, ușă deschisă/închisă). Modelele de obiect adaugă clasificări obiectelor detectate (de exemplu, animale cunoscute, curieri etc.).", + "name": "Nume", + "namePlaceholder": "Introduceți numele modelului...", + "type": "Tip", + "typeState": "Stare", + "typeObject": "Obiect", + "objectLabel": "Etichetă obiect", + "objectLabelPlaceholder": "Selectează tipul obiectului...", + "classificationType": "Tip de clasificare", + "classificationTypeTip": "Află despre tipurile de clasificare", + "classificationTypeDesc": "Subetichetele adaugă text suplimentar la eticheta obiectului (de exemplu, 'Persoană: UPS'). Atributele sunt metadate căutabile, stocate separat în metadatele obiectului.", + "classificationSubLabel": "Subeticheta", + "classificationAttribute": "Atribut", + "classes": "Clase", + "classesTip": "Află despre clase", + "classesStateDesc": "Definește diferitele stări în care poate fi zona camerei tale. De exemplu: 'deschis' și 'închis' pentru o ușă de garaj.", + "classesObjectDesc": "Definește diferitele categorii în care să fie clasificate obiectele detectate. De exemplu: 'curier', 'rezident', 'necunoscut' pentru clasificarea persoanelor.", + "classPlaceholder": "Introduceți numele clasei...", + "errors": { + "nameRequired": "Numele modelului este obligatoriu", + "nameLength": "Numele modelului trebuie să aibă 64 de caractere sau mai puțin", + "nameOnlyNumbers": "Numele modelului nu poate conține doar cifre", + "classRequired": "Este necesară cel puțin 1 clasă", + "classesUnique": "Numele claselor trebuie să fie unice", + "stateRequiresTwoClasses": "Modelele de stare necesită cel puțin 2 clase", + "objectLabelRequired": "Vă rugăm să selectați o etichetă de obiect", + "objectTypeRequired": "Vă rugăm să selectați un tip de clasificare", + "noneNotAllowed": "Clasa 'niciuna' nu este permisă" + }, + "states": "Stări" + }, + "step2": { + "description": "Selectați camerele și definiți zona de monitorizat pentru fiecare cameră. Modelul va clasifica starea acestor zone.", + "cameras": "Camere", + "selectCamera": "Selectează camera", + "noCameras": "Apasă pe + pentru a adăuga camere", + "selectCameraPrompt": "Selectați o cameră din listă pentru a defini aria sa de monitorizare" + }, + "step3": { + "selectImagesPrompt": "Selectați toate imaginile cu: {{className}}", + "selectImagesDescription": "Apăsați pe imagini pentru a le selecta. Apăsați pe Continuare când ați terminat cu această clasă.", + "generating": { + "title": "Generare imagini de exemplu", + "description": "Frigate preia imagini reprezentative din înregistrările tale. Aceasta poate dura câteva momente..." + }, + "training": { + "title": "Antrenare model", + "description": "Modelul tău este antrenat în fundal. Închide această fereastră și modelul va începe să ruleze imediat ce antrenamentul este finalizat." + }, + "retryGenerate": "Reîncearcă generarea", + "noImages": "Nu s-au generat imagini de exemplu", + "classifying": "Clasificare și antrenare...", + "trainingStarted": "Antrenamentul a început cu succes", + "errors": { + "noCameras": "Nu există camere configurate", + "noObjectLabel": "Nu a fost selectată nicio etichetă de obiect", + "generateFailed": "Generarea exemplelor a eșuat: {{error}}", + "generationFailed": "Generarea a eșuat. Vă rugăm să încercați din nou.", + "classifyFailed": "Clasificarea imaginilor a eșuat: {{error}}" + }, + "generateSuccess": "Imaginile de exemplu au fost generate cu succes", + "allImagesRequired_one": "Te rog să clasifici toate imaginile. {{count}} imagine rămasă.", + "allImagesRequired_few": "Te rog să clasifici toate imaginile. {{count}} imagini rămase.", + "allImagesRequired_other": "Te rog să clasifici toate imaginile. {{count}} de imagini rămase.", + "modelCreated": "Modelul a fost creat cu succes. Folosește vizualizarea Clasificări recente pentru a adăuga imagini pentru stările lipsă, apoi antrenează modelul.", + "missingStatesWarning": { + "title": "Exemple de stări lipsă", + "description": "Este recomandat să alegi exemple pentru toate stările pentru rezultate optime. Poți continua fără a selecta toate stările, dar modelul nu va fi antrenat până când toate stările nu au imagini. După continuare, folosește vizualizarea Clasificări recente pentru a clasifica imagini pentru stările lipsă, apoi antrenează modelul." + } + } + }, + "deleteModel": { + "title": "Șterge modelul de clasificare", + "single": "Sigur doriți să ștergeți {{name}}? Aceasta va șterge permanent toate datele asociate, inclusiv imaginile și datele de antrenament. Această acțiune nu poate fi anulată.", + "desc_one": "Sigur doriți să ștergeți {{count}} model? Aceasta va șterge permanent toate datele asociate, inclusiv imaginile și datele de antrenament. Această acțiune nu poate fi anulată.", + "desc_few": "Sigur doriți să ștergeți {{count}} modele? Aceasta va șterge permanent toate datele asociate, inclusiv imaginile și datele de antrenament. Această acțiune nu poate fi anulată.", + "desc_other": "Sigur doriți să ștergeți {{count}} de modele? Aceasta va șterge permanent toate datele asociate, inclusiv imaginile și datele de antrenament. Această acțiune nu poate fi anulată." + }, + "menu": { + "objects": "Obiecte", + "states": "Stări" + }, + "details": { + "scoreInfo": "Scorul reprezintă încrederea medie a clasificării pentru toate detecțiile acestui obiect.", + "none": "Niciuna", + "unknown": "Necunoscut" + }, + "edit": { + "title": "Editează modelul de clasificare", + "descriptionState": "Editează clasele pentru acest model de clasificare a stării. Modificările vor necesita reantrenarea modelului.", + "descriptionObject": "Editează tipul de obiect și tipul de clasificare pentru acest model de clasificare a obiectelor.", + "stateClassesInfo": "Notă: Modificarea claselor de stare necesită reantrenarea modelului cu clasele actualizate." + }, + "tooltip": { + "trainingInProgress": "Modelul este în curs de antrenare", + "noNewImages": "Nu există imagini noi pentru antrenare. Clasifică mai întâi mai multe imagini în setul de date.", + "modelNotReady": "Modelul nu este pregătit pentru antrenare", + "noChanges": "Nicio modificare a setului de date de la ultima antrenare." + }, + "none": "Niciuna" +} diff --git a/web/public/locales/ro/views/configEditor.json b/web/public/locales/ro/views/configEditor.json index cecfb7cc7..165bd90dc 100644 --- a/web/public/locales/ro/views/configEditor.json +++ b/web/public/locales/ro/views/configEditor.json @@ -1,7 +1,7 @@ { - "documentTitle": "Editor configurație - Frigate", + "documentTitle": "Editor de configurație - Frigate", "configEditor": "Editor de configurație", - "copyConfig": "Copiază setările", + "copyConfig": "Copiază", "saveAndRestart": "Salvează și repornește", "saveOnly": "Salvează", "toast": { @@ -12,5 +12,7 @@ "savingError": "Eroare la salvarea setărilor" } }, - "confirm": "Ieși fără să salvezi?" + "confirm": "Ieși fără să salvezi?", + "safeConfigEditor": "Editor de configurație (mod de siguranță)", + "safeModeDescription": "Frigate este în modul de siguranță din cauza unei erori de validare a configurației." } diff --git a/web/public/locales/ro/views/events.json b/web/public/locales/ro/views/events.json index 30ae1ecb1..f4f2ef120 100644 --- a/web/public/locales/ro/views/events.json +++ b/web/public/locales/ro/views/events.json @@ -8,7 +8,11 @@ "empty": { "alert": "Nu sunt alerte de revizuit", "detection": "Nu sunt detecții de revizuit", - "motion": "Nu au fost găsite date despre mișcare" + "motion": "Nu au fost găsite date despre mișcare", + "recordingsDisabled": { + "title": "Înregistrările trebuie să fie activate", + "description": "Elementele de revizuire pot fi create doar pentru o cameră atunci când înregistrările sunt activate pentru acea cameră." + } }, "timeline": "Cronologie", "timeline.aria": "Selectează cronologia", @@ -34,5 +38,30 @@ "detections": "Detecții", "detected": "detectat", "selected_one": "{{count}} selectate", - "selected_other": "{{count}} selectate" + "selected_other": "{{count}} selectate", + "suspiciousActivity": "Activitate suspectă", + "threateningActivity": "Activitate amenințătoare", + "detail": { + "noDataFound": "Nicio dată detaliată de revizuit", + "aria": "Comută vizualizarea detaliată", + "trackedObject_one": "{{count}} obiect", + "trackedObject_other": "{{count}} obiecte", + "noObjectDetailData": "Nicio dată de detaliu obiect disponibilă.", + "label": "Detaliu", + "settings": "Setări vizualizare detaliată", + "alwaysExpandActive": { + "title": "Extinde întotdeauna activul", + "desc": "Extinde întotdeauna detaliile obiectului elementului activ de revizuire, atunci când sunt disponibile." + } + }, + "objectTrack": { + "trackedPoint": "Punct urmărit", + "clickToSeek": "Apasă pentru a naviga la acest moment" + }, + "zoomIn": "Mărește", + "zoomOut": "Micșorează", + "normalActivity": "Normal", + "needsReview": "Necesită revizuire", + "securityConcern": "Potențială problemă de securitate", + "select_all": "Toate" } diff --git a/web/public/locales/ro/views/explore.json b/web/public/locales/ro/views/explore.json index f9b4b0867..d76f9191d 100644 --- a/web/public/locales/ro/views/explore.json +++ b/web/public/locales/ro/views/explore.json @@ -33,7 +33,9 @@ "details": "detalii", "snapshot": "snapshot", "video": "video", - "object_lifecycle": "ciclul de viață al obiectului" + "object_lifecycle": "ciclul de viață al obiectului", + "thumbnail": "miniatură", + "tracking_details": "detalii de urmărire" }, "objectLifecycle": { "lifecycleItemDesc": { @@ -70,7 +72,7 @@ "offset": { "label": "Compensare adnotare", "documentation": "Citește documentația ", - "desc": "Aceste date provin din fluxul de detecție al camerei tale, dar sunt suprapuse pe imaginile din fluxul de înregistrare. Este puțin probabil ca cele două fluxuri să fie perfect sincronizate. Ca urmare, caseta de delimitare și materialul video nu se vor potrivi perfect. Totuși, câmpulannotation_offset poate fi folosit pentru a ajusta acest lucru.",
+ "desc": "Aceste date provin din stream-ul de detecție al camerei tale, dar sunt suprapuse pe imaginile din stream-ul de înregistrare. Este puțin probabil ca cele două stream-uri să fie perfect sincronizate. Ca urmare, caseta de delimitare și materialul video nu se vor potrivi perfect. Totuși, câmpul annotation_offset poate fi folosit pentru a ajusta acest lucru.",
"millisecondsToOffset": "Millisecondele cu care să compensezi adnotările de detecție. Implicit: 0",
"tips": "SFAT: Imaginează-ți că există un clip de eveniment cu o persoană care merge de la stânga la dreapta. Dacă caseta de delimitare de pe linia temporală a evenimentului este constant în partea stângă a persoanei, atunci valoarea ar trebui să fie scăzută. În mod similar, dacă persoana merge de la stânga la dreapta și caseta de delimitare este constant înaintea persoanei, atunci valoarea ar trebui să fie crescută.",
"toast": {
@@ -103,12 +105,16 @@
"success": {
"regenerate": "O nouă descriere a fost solicitată de la {{provider}}. În funcție de viteza furnizorului tău, regenerarea noii descrieri poate dura ceva timp.",
"updatedSublabel": "Subeticheta a fost actualizată cu succes.",
- "updatedLPR": "Plăcuța de înmatriculare a fost actualizată cu succes."
+ "updatedLPR": "Plăcuța de înmatriculare a fost actualizată cu succes.",
+ "audioTranscription": "Transcrierea audio a fost solicitată cu succes. În funcție de viteza serverului dumneavoastră Frigate, transcrierea poate dura ceva timp până la finalizare.",
+ "updatedAttributes": "Atributele au fost actualizate cu succes."
},
"error": {
"updatedSublabelFailed": "Nu s-a putut actualiza sub-etichetarea: {{errorMessage}}",
"updatedLPRFailed": "Plăcuța de înmatriculare nu a putut fi actualizată: {{errorMessage}}",
- "regenerate": "Eroare la apelarea {{provider}} pentru o nouă descriere: {{errorMessage}}"
+ "regenerate": "Eroare la apelarea {{provider}} pentru o nouă descriere: {{errorMessage}}",
+ "audioTranscription": "Solicitarea transcrierii audio a eșuat: {{errorMessage}}",
+ "updatedAttributesFailed": "Actualizarea atributelor a eșuat: {{errorMessage}}"
}
}
},
@@ -153,7 +159,18 @@
},
"expandRegenerationMenu": "Extinde meniul de regenerare",
"regenerateFromSnapshot": "Regenerează din snapshot",
- "regenerateFromThumbnails": "Regenerează din miniaturi"
+ "regenerateFromThumbnails": "Regenerează din miniaturi",
+ "score": {
+ "label": "Scor"
+ },
+ "editAttributes": {
+ "title": "Editează atribute",
+ "desc": "Selectează atributele de clasificare pentru acest {{label}}"
+ },
+ "attributes": "Atribute de clasificare",
+ "title": {
+ "label": "Titlu"
+ }
},
"exploreMore": "Explorează mai multe obiecte cu {{label}}",
"trackedObjectDetails": "Detalii despre obiectul urmărit",
@@ -187,12 +204,34 @@
"submitToPlus": {
"label": "Trimite către Frigate+",
"aria": "Trimite către Frigate Plus"
+ },
+ "addTrigger": {
+ "label": "Adaugă declanșator",
+ "aria": "Adaugă un declanșator pentru acest obiect urmărit"
+ },
+ "audioTranscription": {
+ "label": "Transcrie",
+ "aria": "Solicită transcrierea audio"
+ },
+ "viewTrackingDetails": {
+ "label": "Vizualizați detaliile de urmărire",
+ "aria": "Vizualizați detaliile de urmărire"
+ },
+ "showObjectDetails": {
+ "label": "Afișează traseul obiectului"
+ },
+ "hideObjectDetails": {
+ "label": "Ascunde traseul obiectului"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Descarcă un snapshot curat",
+ "aria": "Descarcă snapshot curat"
}
},
"dialog": {
"confirmDelete": {
"title": "Confirmă ștergerea",
- "desc": "Ștergerea acestui obiect urmărit elimină instantaneul, orice încorporări salvate și orice intrări asociate ciclului de viață al obiectului. Materialul video înregistrat al acestui obiect urmărit în vizualizarea Istoric NU va fi șters.Căi
Liniile și cercurile vor indica punctele semnificative prin care obiectul urmărit s-a deplasat pe parcursul ciclului său de viață.
" + }, + "audio": { + "title": "Audio", + "noAudioDetections": "Nicio detecție audio", + "score": "scor", + "currentRMS": "RMS curent", + "currentdbFS": "dbFS curent" + }, + "openCameraWebUI": "Deschide interfața web pentru {{camera}}" }, "users": { "dialog": { @@ -415,7 +481,8 @@ "admin": "Administrator", "adminDesc": "Acces complet la toate funcțiile.", "viewer": "Vizualizator", - "viewerDesc": "Limitat doar la tablourile de bord Live, Revizuire, Explorare și Exporturi." + "viewerDesc": "Limitat doar la tablourile de bord Live, Revizuire, Explorare și Exporturi.", + "customDesc": "Rol personalizat cu acces specific la cameră." }, "select": "Selectează un rol", "title": "Schimbă rolul utilizatorului" @@ -436,7 +503,16 @@ }, "title": "Parolă", "match": "Parolele se potrivesc", - "notMatch": "Parolele nu se potrivesc" + "notMatch": "Parolele nu se potrivesc", + "show": "Afișează parola", + "hide": "Ascunde parola", + "requirements": { + "title": "Cerințe parolă:", + "length": "Cel puțin 12 caractere", + "uppercase": "Cel puțin o literă majusculă", + "digit": "Cel puțin o cifră", + "special": "Cel puțin un caracter special (!@#$%^&*(),.?\":{}|<>)" + } }, "passwordIsRequired": "Este nevoie de parolă", "user": { @@ -451,7 +527,11 @@ "placeholder": "Re-introdu parola nouă" } }, - "usernameIsRequired": "Este nevoie de numele de utilizator" + "usernameIsRequired": "Este nevoie de numele de utilizator", + "currentPassword": { + "title": "Parola curentă", + "placeholder": "Introduceți parola curentă" + } }, "createUser": { "confirmPassword": "Te rog să confirmi parola", @@ -464,7 +544,12 @@ "doNotMatch": "Parolele nu se potrivesc", "updatePassword": "Actualizează parola pentru {{username}}", "setPassword": "Schimbă parola", - "desc": "Creează o parolă puternică pentru a securiza acest cont." + "desc": "Creează o parolă puternică pentru a securiza acest cont.", + "currentPasswordRequired": "Parola curentă este obligatorie", + "incorrectCurrentPassword": "Parola curentă incorectă", + "passwordVerificationFailed": "Nu s-a putut verifica parola", + "multiDeviceWarning": "Orice alte dispozitive pe care ești autentificat vor trebui să se autentifice din nou în termen de {{refresh_time}}.", + "multiDeviceAdmin": "De asemenea, poți forța toți utilizatorii să se reautentifice imediat prin rotirea secretului tău JWT." } }, "addUser": "Adaugă utilizator", @@ -486,7 +571,7 @@ "deleteUserFailed": "Ștergerea utilizatorului a eșuat: {{errorMessage}}" } }, - "updatePassword": "Actualizează parola", + "updatePassword": "Resetează parola", "title": "Utilizatori", "table": { "username": "Nume utilizator", @@ -495,7 +580,7 @@ "noUsers": "Nu a fost găsit niciun utilizator.", "changeRole": "Schimbă rolul utilizatorului", "deleteUser": "Șterge utilizatorul", - "password": "Parolă" + "password": "Resetează parola" } }, "notification": { @@ -619,5 +704,547 @@ "success": "Setările de mișcare au fost salvate." }, "title": "Reglaj detecție mișcare" + }, + "triggers": { + "documentTitle": "Declanșatoare", + "management": { + "title": "Declanșatoare", + "desc": "Gestionează declanșatoarele pentru {{camera}}. Folosește tipul miniatură pentru a declanșa pe miniaturi similare cu obiectul urmărit selectat și tipul descriere pentru a declanșa pe descrieri similare textului pe care îl specifici." + }, + "addTrigger": "Adaugă declanșator", + "table": { + "name": "Nume", + "type": "Tip", + "content": "Conținut", + "threshold": "Prag", + "actions": "Acțiuni", + "noTriggers": "Nu sunt configurate declanșatoare pentru această cameră.", + "edit": "Editează", + "deleteTrigger": "Elimină declanșatorul", + "lastTriggered": "Ultima declanșare" + }, + "type": { + "thumbnail": "Miniatură", + "description": "Descriere" + }, + "actions": { + "alert": "Marchează ca alertă", + "notification": "Trimite notificare", + "sub_label": "Adaugă subeticheta", + "attribute": "Adaugă atribut" + }, + "dialog": { + "createTrigger": { + "title": "Crează declanșator", + "desc": "Creează un declanșator pentru camera {{camera}}" + }, + "editTrigger": { + "title": "Editează declanșatorul", + "desc": "Editează setările pentru declanșatorul de pe camera {{camera}}" + }, + "deleteTrigger": { + "title": "Elimină declanșatorul", + "desc": "Ești sigur că vrei să ștergi declanșatorul {{triggerName}}? Această acțiune nu poate fi anulată." + }, + "form": { + "name": { + "title": "Nume", + "placeholder": "Denumește acest declanșator", + "error": { + "minLength": "Câmpul trebuie să aibă cel puțin 2 caractere.", + "invalidCharacters": "Câmpul poate conține doar litere, cifre, underscore-uri și cratime.", + "alreadyExists": "Un declanșator cu acest nume există deja pentru această cameră." + }, + "description": "Introduceți un nume sau o descriere unică pentru a identifica acest declanșator" + }, + "enabled": { + "description": "Activează sau dezactivează acest declanșator" + }, + "type": { + "title": "Tip", + "placeholder": "Selectează tipul de declanșator", + "description": "Declanșează atunci când este detectată o descriere de obiect urmărit similară", + "thumbnail": "Declanșează atunci când este detectată o miniatură de obiect urmărit similară" + }, + "content": { + "title": "Conținut", + "imagePlaceholder": "Selectează o miniatură", + "textPlaceholder": "Introdu conținutul textului", + "imageDesc": "Sunt afișate doar ultimele 100 de miniaturi. Dacă nu găsiți miniatura dorită, vă rugăm să verificați obiectele anterioare în Explorator și să configurați un declanșator din meniul de acolo.", + "textDesc": "Introduceți textul pentru a declanșa această acțiune atunci când este detectată o descriere de obiect urmărit similară.", + "error": { + "required": "Conținutul este obligatoriu." + } + }, + "threshold": { + "title": "Prag", + "error": { + "min": "Pragul trebuie să fie cel puțin 0", + "max": "Pragul trebuie să fie cel mult 1" + }, + "desc": "Setați pragul de similitudine pentru acest declanșator. Un prag mai mare înseamnă că este necesară o potrivire mai apropiată pentru declanșarea acestuia." + }, + "actions": { + "title": "Acțiuni", + "desc": "În mod implicit, Frigate trimite un mesaj MQTT pentru toate declanșatoarele. Subetichetele adaugă numele declanșatorului la eticheta obiectului. Atributele sunt metadate căutabile, stocate separat în metadatele obiectului urmărit.", + "error": { + "min": "Trebuie selectată cel puțin o acțiune." + } + }, + "friendly_name": { + "title": "Nume prietenos", + "placeholder": "Denumește sau descrie acest declanșator", + "description": "Un nume prietenos opțional sau un text descriptiv pentru acest declanșator." + } + } + }, + "toast": { + "success": { + "createTrigger": "Declanșatorul {{name}} a fost creat cu succes.", + "updateTrigger": "Declanșatorul {{name}} a fost actualizat cu succes.", + "deleteTrigger": "Declanșatorul {{name}} a fost eliminat cu succes." + }, + "error": { + "createTriggerFailed": "Crearea declanșatorului a eșuat: {{errorMessage}}", + "updateTriggerFailed": "Actualizarea declanșatorului a eșuat: {{errorMessage}}", + "deleteTriggerFailed": "Eliminarea declanșatorului a eșuat: {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "Căutarea semantică este dezactivată", + "desc": "Căutarea semantică trebuie să fie activată pentru a utiliza declanșatoarele." + }, + "wizard": { + "title": "Creează declanșator", + "step1": { + "description": "Configurează setările de bază pentru declanșatorul tău." + }, + "step2": { + "description": "Configurează conținutul care va declanșa această acțiune." + }, + "step3": { + "description": "Configurează pragul și acțiunile pentru acest declanșator." + }, + "steps": { + "nameAndType": "Nume și Tip", + "configureData": "Configurează datele", + "thresholdAndActions": "Prag și Acțiuni" + } + } + }, + "roles": { + "management": { + "title": "Gestionare rol vizualizator", + "desc": "Gestionează rolurile personalizate de vizualizator și permisiunile lor de acces la cameră pentru această instanță Frigate." + }, + "addRole": "Adaugă rol", + "table": { + "role": "Rol", + "cameras": "Camere", + "actions": "Acțiuni", + "noRoles": "Nu au fost găsite roluri personalizate.", + "editCameras": "Editează camerele", + "deleteRole": "Șterge rol" + }, + "toast": { + "success": { + "createRole": "Rolul {{role}} a fost creat cu succes", + "updateCameras": "Camerele au fost actualizate pentru rolul {{role}}", + "deleteRole": "Rolul {{role}} a fost șters cu succes", + "userRolesUpdated_one": "{{count}} utilizator atribuit acestui rol a fost actualizat la „vizualizator”, care are acces la toate camerele.", + "userRolesUpdated_few": "{{count}} utilizatori atribuiți acestui rol au fost actualizați la „vizualizatori”, care are acces la toate camerele.", + "userRolesUpdated_other": "{{count}} de utilizatori atribuiți acestui rol au fost actualizați la „vizualizatori”, care are acces la toate camerele." + }, + "error": { + "createRoleFailed": "Crearea rolului a eșuat: {{errorMessage}}", + "updateCamerasFailed": "Actualizarea camerelor a eșuat: {{errorMessage}}", + "deleteRoleFailed": "Ștergerea rolului a eșuat: {{errorMessage}}", + "userUpdateFailed": "Actualizarea rolurilor utilizatorilor a eșuat: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Creează rol nou", + "desc": "Adaugă un rol nou și specifică permisiunile de acces la camere." + }, + "editCameras": { + "title": "Editează camerele rolului", + "desc": "Actualizează accesul la camere pentru rolul {{role}}." + }, + "deleteRole": { + "title": "Șterge rolul", + "desc": "Această acțiune nu poate fi anulată. Aceasta va șterge permanent rolul și va atribui orice utilizatori cu acest rol la rolul „vizualizator”, care va oferi acces vizualizator la toate camerele.", + "warn": "Ești sigur că vrei să ștergi {{role}}?", + "deleting": "Se șterge..." + }, + "form": { + "role": { + "title": "Nume rol", + "placeholder": "Introduceți numele rolului", + "desc": "Sunt permise doar litere, cifre, puncte și linii de subliniere.", + "roleIsRequired": "Numele rolului este obligatoriu", + "roleOnlyInclude": "Numele rolului poate include doar litere, cifre, . sau _", + "roleExists": "Un rol cu acest nume există deja." + }, + "cameras": { + "title": "Camere", + "desc": "Selectați camerele la care acest rol are acces. Este necesară cel puțin o cameră.", + "required": "Trebuie selectată cel puțin o cameră." + } + } + } + }, + "cameraWizard": { + "title": "Adaugă cameră", + "description": "Urmează pașii de mai jos pentru a adăuga o cameră nouă la sistemul tău Frigate.", + "steps": { + "nameAndConnection": "Nume și Conexiune", + "streamConfiguration": "Configurare streaming", + "validationAndTesting": "Validare și Testare", + "probeOrSnapshot": "Sondează sau fă snapshot" + }, + "save": { + "success": "Camera nouă {{cameraName}} a fost salvată cu succes.", + "failure": "Eroare la salvarea {{cameraName}}." + }, + "testResultLabels": { + "resolution": "Rezoluție", + "video": "Video", + "audio": "Audio", + "fps": "FPS" + }, + "commonErrors": { + "noUrl": "Te rog să furnizezi un URL de streaming valid", + "testFailed": "Testul de streaming a eșuat: {{error}}" + }, + "step1": { + "description": "Introduceți detaliile camerei și alegeți să testați camera sau să selectați manual marca.", + "cameraName": "Nume cameră", + "cameraNamePlaceholder": "ex. usă_intrare sau Vedere Curte Spate", + "host": "Gazdă/Adresă IP", + "port": "Port", + "username": "Nume de utilizator", + "usernamePlaceholder": "Opțional", + "password": "Parolă", + "passwordPlaceholder": "Opțional", + "selectTransport": "Selectează protocolul de transport", + "cameraBrand": "Brand cameră", + "selectBrand": "Selectează marca camerei pentru șablonul de URL", + "customUrl": "URL Streaming Personalizat", + "brandInformation": "Informații despre brand", + "brandUrlFormat": "Pentru camere cu formatul URL RTSP ca: {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://utilizator:parolă@gazdă:port/cale", + "testConnection": "Testează Conexiunea", + "testSuccess": "Testul de conexiune a reușit!", + "testFailed": "Testul de conexiune a eșuat. Te rog să verifici datele introduse și să încerci din nou.", + "streamDetails": "Detalii stream", + "warnings": { + "noSnapshot": "Nu se poate obține un snapshot de pe stream-ul configurat." + }, + "errors": { + "brandOrCustomUrlRequired": "Ori selectează un brand de cameră cu adresă gazdă/IP, ori alege „Alta” cu un URL personalizat", + "nameRequired": "Numele camerei este obligatoriu", + "nameLength": "Numele camerei trebuie să aibă 64 de caractere sau mai puțin", + "invalidCharacters": "Numele camerei conține caractere nevalide", + "nameExists": "Numele camerei există deja", + "brands": { + "reolink-rtsp": "RTSP Reolink nu este recomandat. Activează HTTP în setările firmware ale camerei și repornește asistentul." + }, + "customUrlRtspRequired": "URL-urile personalizate trebuie să înceapă cu \"rtsp://\". Este necesară configurare manuală pentru stream-urile de cameră non-RTSP." + }, + "docs": { + "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras" + }, + "testing": { + "probingMetadata": "Sondare metadate cameră...", + "fetchingSnapshot": "Preluare snapshot cameră..." + }, + "connectionSettings": "Setări conexiune", + "detectionMethod": "Metoda de detecție stream", + "onvifPort": "Port ONVIF", + "probeMode": "Sondare cameră", + "manualMode": "Selecție manuală", + "detectionMethodDescription": "Sondează camera cu ONVIF (dacă este suportat) pentru a găsi URL-urile de stream ale camerei, sau selectează manual marca camerei pentru a utiliza URL-uri predefinite. Pentru a introduce un URL RTSP personalizat, alege metoda manuală și selectează \"Altele\".", + "onvifPortDescription": "Pentru camerele care suportă ONVIF, acesta este de obicei 80 sau 8080.", + "useDigestAuth": "Utilizați autentificarea digest", + "useDigestAuthDescription": "Utilizați autentificarea HTTP digest pentru ONVIF. Unele camere pot necesita un nume de utilizator/parolă ONVIF dedicat în locul utilizatorului standard de administrare." + }, + "step2": { + "description": "Testează camera pentru fluxurile disponibile sau configurează setările manuale pe baza metodei de detectare selectate.", + "streamsTitle": "Stream-uri cameră", + "addStream": "Adaugă stream", + "addAnotherStream": "Adaugă un alt stream", + "streamTitle": "Stream {{number}}", + "streamUrl": "URL stream", + "streamUrlPlaceholder": "rtsp://utilizator:parolă@gazdă:port/cale", + "url": "URL", + "resolution": "Rezoluție", + "selectResolution": "Selectează rezoluția", + "quality": "Calitate", + "selectQuality": "Selectează calitatea", + "roles": "Roluri", + "roleLabels": { + "detect": "Detecție obiecte", + "record": "Înregistrare", + "audio": "Audio" + }, + "testStream": "Testează conexiunea", + "testSuccess": "Testul de conexiune a fost realizat cu succes!", + "testFailed": "Testul de conexiune a eșuat. Verifică datele introduse și încearcă din nou.", + "testFailedTitle": "Test eșuat", + "connected": "Conectat", + "notConnected": "Neconectat", + "featuresTitle": "Funcționalități", + "go2rtc": "Redu conexiunile la cameră", + "detectRoleWarning": "Cel puțin un stream trebuie să aibă rolul „detectare” pentru a continua.", + "rolesPopover": { + "title": "Roluri de streaming", + "detect": "Stream principal pentru detecția obiectelor.", + "record": "Salvează segmente ale stream-ului video pe baza setărilor de configurare.", + "audio": "Stream pentru detecția bazată pe sunet." + }, + "featuresPopover": { + "title": "Funcționalități streaming", + "description": "Folosește restreaming go2rtc pentru a reduce conexiunile la cameră." + }, + "streamDetails": "Detalii stream", + "probing": "Se sondează camera...", + "retry": "Reîncercare", + "testing": { + "probingMetadata": "Se sondează metadatele camerei...", + "fetchingSnapshot": "Se aduce snapshot cameră..." + }, + "probeFailed": "Sondarea camerei a eșuat: {{error}}", + "probingDevice": "Se sondează dispozitivul...", + "probeSuccessful": "Sondare reușită", + "probeError": "Eroare la sondare", + "probeNoSuccess": "Sondare nereușită", + "deviceInfo": "Informații dispozitiv", + "manufacturer": "Producător", + "model": "Model", + "firmware": "Firmware", + "profiles": "Profiluri", + "ptzSupport": "Suport PTZ", + "autotrackingSupport": "Suport autourmărire", + "presets": "Presetări", + "rtspCandidates": "Candidați RTSP", + "rtspCandidatesDescription": "Următoarele URL-uri RTSP au fost găsite în urma sondării camerei. Testați conexiunea pentru a vizualiza metadatele stream-ului.", + "noRtspCandidates": "Nu au fost găsite URL-uri RTSP de la cameră. Este posibil ca datele dumneavoastră de autentificare să fie incorecte, sau este posibil ca aparatul foto să nu suporte ONVIF sau metoda utilizată pentru a prelua URL-urile RTSP. Întoarceți-vă și introduceți URL-ul RTSP manual.", + "candidateStreamTitle": "Candidat {{number}}", + "useCandidate": "Folosește", + "uriCopy": "Copiază", + "uriCopied": "URI copiat în clipboard", + "testConnection": "Testează conexiunea", + "toggleUriView": "Click pentru a comuta vizualizarea URI completă", + "errors": { + "hostRequired": "Gazdă/adresaIP este necesară" + } + }, + "step3": { + "description": "Configurează rolurile stream-ului și adaugă stream-uri suplimentare pentru camera ta.", + "validationTitle": "Validare stream", + "connectAllStreams": "Conectează toate stream-urile", + "reconnectionSuccess": "Reconectare reușită.", + "reconnectionPartial": "Unele stram-uri nu s-au reconectat.", + "streamUnavailable": "Previzualizare streaming indisponibilă", + "reload": "Reîncarcă", + "connecting": "Conectare...", + "streamTitle": "Stream {{number}}", + "valid": "Valid", + "failed": "Eșuat", + "notTested": "Netestat", + "connectStream": "Conectare", + "connectingStream": "Se conectează", + "disconnectStream": "Deconectare", + "estimatedBandwidth": "Lățime de bandă estimată", + "roles": "Roluri", + "none": "Niciunul", + "error": "Eroare", + "streamValidated": "Stream {{number}} validat cu succes", + "streamValidationFailed": "Validarea pentru stream {{number}} a eșuat", + "saveAndApply": "Salvează Camera Nouă", + "saveError": "Configurație invalidă. Verifică setările.", + "issues": { + "title": "Validare stream", + "videoCodecGood": "Codecul video este {{codec}}.", + "audioCodecGood": "Codecul audio este {{codec}}.", + "noAudioWarning": "Nu s-a detectat audio pentru acest strem, înregistrările nu vor avea sunet.", + "audioCodecRecordError": "Codec-ul audio AAC este necesar pentru a suporta audio în înregistrări.", + "audioCodecRequired": "Un stream audio este necesar pentru a suporta detecția audio.", + "restreamingWarning": "Reducerea conexiunilor la cameră pentru stream-ul de înregistrare poate crește ușor utilizarea procesorului.", + "dahua": { + "substreamWarning": "Substream-ul 1 este blocat la o rezoluție scăzută. Multe camere Dahua / Amcrest / EmpireTech suportă substream-uri suplimentare care trebuie să fie activate în setările camerei. Este recomandat să verifici și să utilizezi acele stream-uri, dacă sunt disponibile." + }, + "hikvision": { + "substreamWarning": "Substream-ul 1 este blocat la o rezoluție scăzută. Multe camere Hikvision suportă substream-uri suplimentare care trebuie să fie activate în setările camerei. Este recomandat să verifici și să utilizezi acele strem-uri, dacă sunt disponibile." + }, + "resolutionHigh": "O rezoluție de {{resolution}} poate cauza o utilizare crescută a resurselor.", + "resolutionLow": "O rezoluție de {{resolution}} poate fi prea mică pentru detectarea fiabilă a obiectelor mici." + }, + "ffmpegModule": "Folosește modul de compatibilitate pentru stream-uri", + "ffmpegModuleDescription": "Dacă fluxul nu se încarcă după mai multe încercări, activați această opțiune. Când este activată, Frigate va folosi modulul ffmpeg împreună cu go2rtc. Aceasta poate oferi o compatibilitate mai bună cu unele fluxuri de camere.", + "streamsTitle": "Stream-uri cameră", + "addStream": "Adaugă stream", + "addAnotherStream": "Adaugă alt stream", + "streamUrl": "URL stream", + "streamUrlPlaceholder": "rtsp://utilizator:parolă@adresaIP:port/cale", + "selectStream": "Selectați un flux", + "searchCandidates": "Căutați candidați...", + "noStreamFound": "Niciun stream găsit", + "url": "URL", + "resolution": "Rezoluție", + "quality": "Calitate", + "selectResolution": "Selectează rezoluția", + "selectQuality": "Selectează calitatea", + "roleLabels": { + "detect": "Detecție Obiect", + "record": "Înregistrare", + "audio": "Audio" + }, + "testStream": "Testează conexiunea", + "testSuccess": "Testul stream-ului a avut succes!", + "testFailed": "Testul stream-ului a eșuat", + "testFailedTitle": "Testul a eșuat", + "connected": "Conectat", + "notConnected": "Neconectat", + "featuresTitle": "Funcționalități", + "go2rtc": "Reduceți conexiunile la cameră", + "detectRoleWarning": "Cel puțin un stream trebuie să aibă rolul \"detect\" pentru a continua.", + "rolesPopover": { + "title": "Roluri stream", + "detect": "Stream principal pentru detecția obiectelor.", + "record": "Salvează segmente ale stream-ului video pe baza setărilor de configurare.", + "audio": "Stream pentru detecția bazată pe audio." + }, + "featuresPopover": { + "title": "Funcționalități stream", + "description": "Utilizați go2rtc restreaming pentru a reduce conexiunile la cameră." + } + }, + "step4": { + "description": "Validare finală și analiză înainte de a salva noua cameră. Conectați fiecare stream înainte de a salva.", + "validationTitle": "Validare stream", + "connectAllStreams": "Conectează toate stream-urile", + "reconnectionSuccess": "Reconectare reușită.", + "reconnectionPartial": "Unele stream-uri nu au reușit să se reconecteze.", + "streamUnavailable": "Previzualizare flux indisponibilă", + "reload": "Reîncarcă", + "connecting": "Conectare...", + "streamTitle": "Stream {{number}}", + "valid": "Valid", + "failed": "Eșuat", + "notTested": "Netestat", + "connectStream": "Conectare", + "connectingStream": "Se conectează", + "disconnectStream": "Deconectare", + "estimatedBandwidth": "Lățime de bandă estimată", + "roles": "Roluri", + "ffmpegModule": "Utilizează modul de compatibilitate stream", + "ffmpegModuleDescription": "Dacă stream-ul nu se încarcă după câteva încercări, activați această opțiune. Când este activată, Frigate va utiliza modulul ffmpeg cu go2rtc. Acest lucru poate oferi o compatibilitate mai bună cu unele stream-uri de cameră.", + "none": "Niciuna", + "error": "Eroare", + "streamValidated": "Stream-ul {{number}} validat cu succes", + "streamValidationFailed": "Validarea stream-ului {{number}} a eșuat", + "saveAndApply": "Salvează camera nouă", + "saveError": "Configurație nevalidă. Vă rugăm să vă verificați setările.", + "issues": { + "title": "Validare stream", + "videoCodecGood": "Codecul video: {{codec}}.", + "audioCodecGood": "Codecul audio: {{codec}}.", + "resolutionHigh": "O rezoluție de {{resolution}} poate cauza o utilizare crescută a resurselor.", + "resolutionLow": "O rezoluție de {{resolution}} ar putea fi prea mică pentru detectarea fiabilă a obiectelor mici.", + "noAudioWarning": "Nu a fost detectat audio pentru acest stream, înregistrările nu vor avea audio.", + "audioCodecRecordError": "Codec-ul audio AAC este necesar pentru a suporta audio în înregistrări.", + "audioCodecRequired": "Este necesar un stream audio pentru a suporta detecția audio.", + "restreamingWarning": "Reducerea conexiunilor la cameră pentru stream-ul de înregistrare poate crește ușor utilizarea procesorului (CPU).", + "brands": { + "reolink-rtsp": "RTSP Reolink nu este recomandat. Activați HTTP în setările de firmware ale camerei și reporniți asistentul.", + "reolink-http": "Stream-urile HTTP Reolink ar trebui să folosească FFmpeg pentru o compatibilitate mai bună. Activează 'Use stream compatibility mode' pentru acest stream." + }, + "dahua": { + "substreamWarning": "Substream-ul 1 este blocat la o rezoluție scăzută. Multe camere Dahua / Amcrest / EmpireTech suportă stream-uri secundare suplimentare care trebuie activate în setările camerei. Se recomandă să verificați și să utilizați aceste stream-uri dacă sunt disponibile." + }, + "hikvision": { + "substreamWarning": "Substream-ul 1 este blocat la o rezoluție scăzută. Multe camere Hikvision suportă stream-uri secundare suplimentare care trebuie activate în setările camerei. Se recomandă să verificați și să utilizați aceste stream-uri dacă sunt disponibile." + } + } + } + }, + "cameraManagement": { + "title": "Administrează Camerele", + "addCamera": "Adaugă cameră nouă", + "editCamera": "Editează cameră:", + "selectCamera": "Selectează o cameră", + "backToSettings": "Înapoi la setările camerei", + "streams": { + "title": "Activează / dezactivează camere", + "desc": "Dezactivează temporar o cameră până la repornirea Frigate. Dezactivarea unei camere oprește complet procesarea streamingului acestei camere de către Frigate. Detecția, înregistrarea și depanarea vor fi indisponibile.ffprobe.",
"aspectRatio": "raport aspect",
"fetching": "Se preiau datele camerei",
@@ -134,7 +162,7 @@
"audio": "Sunet:",
"error": "Eroare:{{error}}",
"tips": {
- "title": "Informații sondă cameră"
+ "title": "Informații test cameră"
},
"fps": "Cadre/s:",
"unknown": "Necunoscut"
@@ -160,10 +188,10 @@
"framesAndDetections": "Cadre / Detecții",
"toast": {
"success": {
- "copyToClipboard": "Datele sondei au fost copiate."
+ "copyToClipboard": "Datele testului au fost copiate."
},
"error": {
- "unableToProbeCamera": "Sondarea camerei nu a fost posibilă: {{errorMessage}}"
+ "unableToProbeCamera": "Testarea camerei nu a fost posibilă: {{errorMessage}}"
}
}
},
@@ -174,7 +202,8 @@
"detectHighCpuUsage": "Camera {{camera}} are o utilizare ridicată a procesorului pentru detecție ({{detectAvg}}%)",
"ffmpegHighCpuUsage": "Camera {{camera}} are o utilizare ridicată a procesorului FFmpeg ({{ffmpegAvg}}%)",
"cameraIsOffline": "{{camera}} este offline",
- "healthy": "Sistemul funcționează normal"
+ "healthy": "Sistemul funcționează normal",
+ "shmTooLow": "Alocarea /dev/shm ({{total}} MB) ar trebui mărită la cel puțin {{min}} MB."
},
"lastRefreshed": "Ultima reîmprospătare: "
}
diff --git a/web/public/locales/ru/audio.json b/web/public/locales/ru/audio.json
index 9f5e58530..e9e6bfc21 100644
--- a/web/public/locales/ru/audio.json
+++ b/web/public/locales/ru/audio.json
@@ -315,7 +315,7 @@
"slam": "Хлопок",
"knock": "Стук",
"tap": "Небольшой стук",
- "squeak": "Скрип",
+ "squeak": "Писк",
"cupboard_open_or_close": "Открытие или закрытие шкафа",
"drawer_open_or_close": "Открытие или закрытие ящика",
"dishes": "Тарелки",
@@ -425,5 +425,79 @@
"pink_noise": "Розовый шум",
"hammer": "Молоток",
"firecracker": "Петарда",
- "television": "Телевидение"
+ "television": "Телевидение",
+ "echo": "Эхо",
+ "noise": "Шум",
+ "mains_hum": "Гул сети",
+ "cacophony": "Какофония",
+ "throbbing": "Пульсирующий",
+ "vibration": "Вибрация",
+ "sodeling": "Соделинг",
+ "chird": "Чирд",
+ "change_ringing": "Перезвон",
+ "shofar": "Шофар",
+ "liquid": "Жидкость",
+ "splash": "Брызги",
+ "slosh": "Плеск",
+ "squish": "Хлюпанье",
+ "drip": "Капля",
+ "pour": "Литьё",
+ "trickle": "Струйка",
+ "gush": "Бурный поток",
+ "fill": "Наполнение",
+ "spray": "Распыление",
+ "pump": "Насос",
+ "stir": "Перемешивание",
+ "boiling": "Кипение",
+ "sonar": "Сонар",
+ "arrow": "Стрела",
+ "whoosh": "Вжух",
+ "thump": "Глухой удар",
+ "thunk": "Тупой удар",
+ "electronic_tuner": "Электронный тюнер",
+ "effects_unit": "Блок эффектов",
+ "chorus_effect": "Эффект хоруса",
+ "basketball_bounce": "Отскок баскетбольного мяча",
+ "bang": "Бах",
+ "slap": "Шлепок",
+ "whack": "Удар",
+ "smash": "Разбивание",
+ "breaking": "Разрушение",
+ "bouncing": "Отскок",
+ "whip": "Хлыст",
+ "flap": "Хлопание",
+ "scratch": "Царапанье",
+ "scrape": "Скребок",
+ "rub": "Трение",
+ "roll": "Качение",
+ "crushing": "Дробление",
+ "crumpling": "Сминание",
+ "tearing": "Разрывание",
+ "beep": "Бип",
+ "ping": "Пинг",
+ "ding": "Динь",
+ "clang": "Лязг",
+ "squeal": "Визг",
+ "creak": "Скрипение",
+ "rustle": "Шуршание",
+ "whir": "Жужжание",
+ "clatter": "Грохот",
+ "sizzle": "Шипение",
+ "clicking": "Щелканье",
+ "clickety_clack": "Щелчок-Клак",
+ "rumble": "Грохотать",
+ "plop": "Плюх",
+ "hum": "Гул",
+ "zing": "Зинг",
+ "boing": "Боинг",
+ "crunch": "Хруст",
+ "sine_wave": "Синусоида",
+ "harmonic": "Гармоника",
+ "chirp_tone": "Тон чириканья",
+ "pulse": "Импульс",
+ "inside": "Внутри",
+ "outside": "Снаружи",
+ "reverberation": "Реверберация",
+ "distortion": "Искажение",
+ "sidetone": "Боковой тон"
}
diff --git a/web/public/locales/ru/common.json b/web/public/locales/ru/common.json
index 92ee6cf94..54e214855 100644
--- a/web/public/locales/ru/common.json
+++ b/web/public/locales/ru/common.json
@@ -87,9 +87,13 @@
"formattedTimestampMonthDayYear": {
"12hour": "d MMM, yyyy",
"24hour": "d MMM, yyyy"
- }
+ },
+ "inProgress": "В процессе",
+ "invalidStartTime": "Некорректное время начала",
+ "invalidEndTime": "Некорректное время окончания",
+ "never": "Никогда"
},
- "selectItem": "Выбор {{item}}",
+ "selectItem": "Выбрать {{item}}",
"button": {
"apply": "Применить",
"done": "Готово",
@@ -125,10 +129,17 @@
"unselect": "Снять выбор",
"export": "Экспортировать",
"deleteNow": "Удалить сейчас",
- "next": "Следующий"
+ "next": "Следующий",
+ "continue": "Продолжить"
},
"label": {
- "back": "Вернуться"
+ "back": "Вернуться",
+ "hide": "Скрыть {{item}}",
+ "show": "Показать {{item}}",
+ "ID": "ID",
+ "all": "Все",
+ "none": "Ничего",
+ "other": "Другой"
},
"unit": {
"speed": {
@@ -138,6 +149,14 @@
"length": {
"meters": "метры",
"feet": "футы"
+ },
+ "data": {
+ "kbps": "кБ/с",
+ "mbps": "МБ/с",
+ "gbps": "ГБ/с",
+ "kbph": "кБ/час",
+ "mbph": "МБ/час",
+ "gbph": "ГБ/час"
}
},
"menu": {
@@ -182,7 +201,15 @@
},
"yue": "粵語 (Кантонский)",
"th": "ไทย (Тайский)",
- "ca": "Català (Каталонский)"
+ "ca": "Català (Каталонский)",
+ "ptBR": "Português brasileiro (Бразильский португальский)",
+ "sr": "Српски (Сербский)",
+ "sl": "Slovenščina (Словенский)",
+ "lt": "Lietuvių (Литовский)",
+ "bg": "Български (Болгарский)",
+ "gl": "Galego (Галисийский)",
+ "id": "Bahasa Indonesia (Индонезийский)",
+ "ur": "اردو (Урду)"
},
"darkMode": {
"withSystem": {
@@ -232,7 +259,8 @@
"logout": "Выход",
"setPassword": "Установить пароль"
},
- "appearance": "Внешний вид"
+ "appearance": "Внешний вид",
+ "classification": "Распознование"
},
"pagination": {
"label": "пагинация",
@@ -271,5 +299,18 @@
"admin": "Администратор",
"viewer": "Наблюдатель",
"desc": "Администраторы имеют полный доступ ко всем функциям в интерфейсе Frigate. Наблюдатели ограничены просмотром камер, элементов просмотра и архивных записей."
+ },
+ "readTheDocumentation": "Читать документацию",
+ "information": {
+ "pixels": "{{area}}px"
+ },
+ "list": {
+ "two": "{{0}} и {{1}}",
+ "many": "{{items}}, и {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Необязательный",
+ "internalID": "Внутренний идентификатор Frigate, используемый в конфигурации и базе данных"
}
}
diff --git a/web/public/locales/ru/components/auth.json b/web/public/locales/ru/components/auth.json
index b227af835..17b983914 100644
--- a/web/public/locales/ru/components/auth.json
+++ b/web/public/locales/ru/components/auth.json
@@ -10,6 +10,7 @@
"loginFailed": "Ошибка входа",
"unknownError": "Неизвестная ошибка. Проверьте логи.",
"webUnknownError": "Неизвестная ошибка. Проверьте логи консоли."
- }
+ },
+ "firstTimeLogin": "Пытаетесь войти в систему впервые? Учетные данные указаны в логах Frigate."
}
}
diff --git a/web/public/locales/ru/components/camera.json b/web/public/locales/ru/components/camera.json
index 3059b83f0..8a8c1a492 100644
--- a/web/public/locales/ru/components/camera.json
+++ b/web/public/locales/ru/components/camera.json
@@ -66,7 +66,8 @@
"title": "Настройки видеопотока {{cameraName}}",
"stream": "Поток",
"placeholder": "Выбрать поток"
- }
+ },
+ "birdseye": "Birdseye"
}
},
"debug": {
diff --git a/web/public/locales/ru/components/dialog.json b/web/public/locales/ru/components/dialog.json
index 078a37a97..b935670c2 100644
--- a/web/public/locales/ru/components/dialog.json
+++ b/web/public/locales/ru/components/dialog.json
@@ -65,12 +65,13 @@
"export": "Экспорт",
"selectOrExport": "Выбрать или экспортировать",
"toast": {
- "success": "Экспорт успешно запущен. Файл доступен в папке /exports.",
+ "success": "Экспорт успешно запущен. Файл доступен на странице экспорта.",
"error": {
"failed": "Не удалось запустить экспорт: {{error}}",
"noVaildTimeSelected": "Не выбран допустимый временной диапазон",
"endTimeMustAfterStartTime": "Время окончания должно быть после времени начала"
- }
+ },
+ "view": "Просмотр"
},
"fromTimeline": {
"saveExport": "Сохранить экспорт",
@@ -120,7 +121,16 @@
"button": {
"export": "Экспорт",
"markAsReviewed": "Пометить как просмотренное",
- "deleteNow": "Удалить сейчас"
+ "deleteNow": "Удалить сейчас",
+ "markAsUnreviewed": "Отметить как непросмотренное"
}
+ },
+ "imagePicker": {
+ "search": {
+ "placeholder": "Искать по метке..."
+ },
+ "selectImage": "Выбор миниатюры отслеживаемого объекта",
+ "noImages": "Не обнаружено миниатюр для этой камеры",
+ "unknownLabel": "Сохраненное изображение триггера"
}
}
diff --git a/web/public/locales/ru/components/filter.json b/web/public/locales/ru/components/filter.json
index 024ebe02c..095ea91ba 100644
--- a/web/public/locales/ru/components/filter.json
+++ b/web/public/locales/ru/components/filter.json
@@ -116,12 +116,26 @@
"title": "Распознанные номерные знаки",
"loadFailed": "Не удалось загрузить распознанные номерные знаки.",
"loading": "Загрузка распознанных номерных знаков…",
- "selectPlatesFromList": "Выберите один или более знаков из списка."
+ "selectPlatesFromList": "Выберите один или более знаков из списка.",
+ "selectAll": "Выбрать все",
+ "clearAll": "Очистить все"
},
"review": {
"showReviewed": "Показать просмотренные"
},
"motion": {
"showMotionOnly": "Показывать только движение"
+ },
+ "classes": {
+ "label": "Классы",
+ "all": {
+ "title": "Все классы"
+ },
+ "count_one": "{{count}} класс",
+ "count_other": "{{count}} классы"
+ },
+ "attributes": {
+ "label": "Атрибуты классификации",
+ "all": "Все атрибуты"
}
}
diff --git a/web/public/locales/ru/views/classificationModel.json b/web/public/locales/ru/views/classificationModel.json
new file mode 100644
index 000000000..b5b7e2222
--- /dev/null
+++ b/web/public/locales/ru/views/classificationModel.json
@@ -0,0 +1,193 @@
+{
+ "documentTitle": "Классификация моделей - Frigate",
+ "details": {
+ "scoreInfo": "Оценка представляет собой среднюю степень достоверности классификации по всем обнаружениям данного объекта.",
+ "none": "Нет",
+ "unknown": "Неизвестно"
+ },
+ "button": {
+ "deleteClassificationAttempts": "Удалить изображения классификации",
+ "renameCategory": "Переименовать класс",
+ "deleteCategory": "Удалить класс",
+ "deleteImages": "Удалить изображения",
+ "trainModel": "Тренировать модель",
+ "addClassification": "Добавить классификацию",
+ "deleteModels": "Удалить модели",
+ "editModel": "Редактировать модель"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Класс удалён",
+ "deletedImage": "Изображения удалены",
+ "deletedModel_one": "Успешно удалена {{count}} модель",
+ "deletedModel_few": "Успешно удалены {{count}} модели",
+ "deletedModel_many": "Успешно удалены {{count}} моделей",
+ "categorizedImage": "Изображение успешно классифицировано",
+ "trainedModel": "Модель успешно обучена.",
+ "trainingModel": "Обучение модели успешно запущено.",
+ "updatedModel": "Конфигурация модели успешно обновлена",
+ "renamedCategory": "Класс успешно переименован в {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Не удалось удалить: {{errorMessage}}",
+ "deleteCategoryFailed": "Не удалось удалить класс: {{errorMessage}}",
+ "deleteModelFailed": "Не удалось удалить модель: {{errorMessage}}",
+ "categorizeFailed": "Не удалось классифицировать изображение: {{errorMessage}}",
+ "trainingFailed": "Ошибка обучения модели. Проверьте логи Frigate для получения подробной информации.",
+ "updateModelFailed": "Не удалось обновить модель: {{errorMessage}}",
+ "renameCategoryFailed": "Не удалось переименовать класс: {{errorMessage}}",
+ "trainingFailedToStart": "Не удалось начать обучение модели: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Удалить класс",
+ "desc": "Вы уверены, что хотите удалить класс {{name}}? Это приведёт к безвозвратному удалению всех связанных с ним изображений и потребует повторного обучения модели.",
+ "minClassesTitle": "Не удалось удалить класс",
+ "minClassesDesc": "Модель классификации должна содержать как минимум 2 класса. Добавьте ещё один класс перед удалением этого."
+ },
+ "deleteModel": {
+ "title": "Удалить модель классификации",
+ "single": "Вы уверены, что хотите удалить {{name}}? Это приведёт к безвозвратному удалению всех связанных данных, включая изображения и данные обучения. Это действие нельзя отменить.",
+ "desc_one": "Вы уверены, что хотите удалить {{count}} модель? Это приведёт к безвозвратному удалению всех связанных данных, включая изображения и данные обучения. Это действие нельзя отменить.",
+ "desc_few": "Вы уверены, что хотите удалить {{count}} модели? Это приведёт к безвозвратному удалению всех связанных данных, включая изображения и данные обучения. Это действие нельзя отменить.",
+ "desc_many": "Вы уверены, что хотите удалить {{count}} моделей? Это приведёт к безвозвратному удалению всех связанных данных, включая изображения и данные обучения. Это действие нельзя отменить."
+ },
+ "edit": {
+ "title": "Редактировать модель классификации",
+ "descriptionState": "Редактировать классы для этой модели классификации состояний. Изменения потребуют повторного обучения модели.",
+ "descriptionObject": "Редактировать тип объекта и тип классификации для этой модели классификации объектов.",
+ "stateClassesInfo": "Примечание: изменение классов состояний требует повторного обучения модели с обновлёнными классами."
+ },
+ "deleteDatasetImages": {
+ "title": "Удалить изображения набора данных",
+ "desc_one": "Вы уверены, что хотите удалить {{count}} изображение из {{dataset}}? Это действие нельзя отменить и потребует повторного обучения модели.",
+ "desc_few": "Вы уверены, что хотите удалить {{count}} изображения из {{dataset}}? Это действие нельзя отменить и потребует повторного обучения модели.",
+ "desc_many": "Вы уверены, что хотите удалить {{count}} изображений из {{dataset}}? Это действие нельзя отменить и потребует повторного обучения модели."
+ },
+ "deleteTrainImages": {
+ "title": "Удалить обучающие изображения",
+ "desc_one": "Вы уверены, что хотите удалить {{count}} изображение? Это действие нельзя отменить.",
+ "desc_few": "Вы уверены, что хотите удалить {{count}} изображения? Это действие нельзя отменить.",
+ "desc_many": "Вы уверены, что хотите удалить {{count}} изображений? Это действие нельзя отменить."
+ },
+ "renameCategory": {
+ "title": "Переименовать класс",
+ "desc": "Введите новое имя для {{name}}. Вам потребуется повторно обучить модель, чтобы изменение имени вступило в силу."
+ },
+ "description": {
+ "invalidName": "Недопустимое имя. Имена могут содержать только буквы, цифры, пробелы, апострофы, подчёркивания и дефисы."
+ },
+ "train": {
+ "title": "Недавние классификации",
+ "titleShort": "Недавнее",
+ "aria": "Выбрать недавние классификации"
+ },
+ "categories": "Классы",
+ "createCategory": {
+ "new": "Создать новый класс"
+ },
+ "categorizeImageAs": "Классифицировать изображение как:",
+ "categorizeImage": "Классифицировать изображение",
+ "menu": {
+ "objects": "Объекты",
+ "states": "Состояния"
+ },
+ "noModels": {
+ "object": {
+ "title": "Нет моделей классификации объектов",
+ "description": "Создайте пользовательскую модель для классификации обнаруженных объектов.",
+ "buttonText": "Создать модель объекта"
+ },
+ "state": {
+ "title": "Нет моделей классификации состояний",
+ "description": "Создайте пользовательскую модель для мониторинга и классификации изменений состояний в определённых областях камеры.",
+ "buttonText": "Создать модель состояния"
+ }
+ },
+ "wizard": {
+ "title": "Создать новую классификацию",
+ "steps": {
+ "nameAndDefine": "Имя и определение",
+ "stateArea": "Область состояния",
+ "chooseExamples": "Выбрать примеры"
+ },
+ "step1": {
+ "description": "Модели состояний отслеживают фиксированные области камеры на предмет изменений (например, дверь открыта/закрыта). Модели объектов добавляют классификации к обнаруженным объектам (например, известные животные, курьеры и т.д.).",
+ "name": "Имя",
+ "namePlaceholder": "Введите имя модели…",
+ "type": "Тип",
+ "typeState": "Состояние",
+ "typeObject": "Объект",
+ "objectLabel": "Метка объекта",
+ "objectLabelPlaceholder": "Выберите тип объекта…",
+ "classificationType": "Тип классификации",
+ "classificationTypeTip": "Узнать о типах классификации",
+ "classificationTypeDesc": "Подметки добавляют дополнительный текст к метке объекта (например, 'Человек: UPS'). Атрибуты — это доступные для поиска метаданные, хранящиеся отдельно в метаданных объекта.",
+ "classificationSubLabel": "Подметка",
+ "classificationAttribute": "Атрибут",
+ "classes": "Классы",
+ "states": "Состояния",
+ "classesTip": "Узнать о классах",
+ "classesStateDesc": "Определите различные состояния, в которых может находиться область вашей камеры. Например: 'открыто' и 'закрыто' для гаражных ворот.",
+ "classesObjectDesc": "Определите различные категории для классификации обнаруженных объектов. Например: 'курьер', 'житель', 'незнакомец' для классификации людей.",
+ "classPlaceholder": "Введите имя класса…",
+ "errors": {
+ "nameRequired": "Имя модели обязательно",
+ "nameLength": "Имя модели должно содержать не более 64 символов",
+ "nameOnlyNumbers": "Имя модели не может состоять только из цифр",
+ "classRequired": "Требуется хотя бы 1 класс",
+ "classesUnique": "Имена классов должны быть уникальными",
+ "stateRequiresTwoClasses": "Модели состояний требуют не менее 2 классов",
+ "objectLabelRequired": "Пожалуйста, выберите метку объекта",
+ "objectTypeRequired": "Пожалуйста, выберите тип классификации",
+ "noneNotAllowed": "Класс 'нет' не допускается"
+ }
+ },
+ "step2": {
+ "description": "Выберите камеры и определите область для мониторинга для каждой камеры. Модель будет классифицировать состояние этих областей.",
+ "cameras": "Камеры",
+ "selectCamera": "Выбрать камеру",
+ "noCameras": "Нажмите +, чтобы добавить камеры",
+ "selectCameraPrompt": "Выберите камеру из списка, чтобы определить область её мониторинга"
+ },
+ "step3": {
+ "selectImagesPrompt": "Выберите все изображения с {{className}}",
+ "selectImagesDescription": "Нажмите на изображения, чтобы выбрать их. Нажмите Продолжить, когда закончите с этим классом.",
+ "generating": {
+ "title": "Генерация примеров изображений",
+ "description": "Frigate извлекает репрезентативные изображения из ваших записей. Это может занять некоторое время…"
+ },
+ "training": {
+ "title": "Обучение модели",
+ "description": "Ваша модель обучается в фоновом режиме. Закройте это диалоговое окно, и ваша модель начнёт работать, как только обучение будет завершено."
+ },
+ "retryGenerate": "Повторить генерацию",
+ "noImages": "Примеры изображений не сгенерированы",
+ "classifying": "Классификация и обучение…",
+ "trainingStarted": "Обучение успешно запущено",
+ "errors": {
+ "noCameras": "Камеры не настроены",
+ "noObjectLabel": "Метка объекта не выбрана",
+ "generateFailed": "Не удалось сгенерировать примеры: {{error}}",
+ "generationFailed": "Генерация не удалась. Пожалуйста, попробуйте снова.",
+ "classifyFailed": "Не удалось классифицировать изображения: {{error}}"
+ },
+ "generateSuccess": "Примеры изображений успешно сгенерированы",
+ "allImagesRequired_one": "Пожалуйста, классифицируйте все изображения. Осталось {{count}} изображение.",
+ "allImagesRequired_few": "Пожалуйста, классифицируйте все изображения. Осталось {{count}} изображения.",
+ "allImagesRequired_many": "Пожалуйста, классифицируйте все изображения. Осталось {{count}} изображений.",
+ "modelCreated": "Модель успешно создана. Используйте раздел \"Последние классификации\", чтобы добавить изображения для отсутствующих состояний, а затем обучите модель.",
+ "missingStatesWarning": {
+ "title": "Примеры отсутствующих состояний",
+ "description": "Рекомендуется выбрать примеры для всех состояний для достижения наилучших результатов. Вы можете продолжить, не выбрав все состояния, но модель не будет обучена, пока для всех состояний не появятся изображения. После продолжения используйте раздел «Последние классификации», чтобы классифицировать изображения для отсутствующих состояний, а затем обучите модель."
+ }
+ }
+ },
+ "tooltip": {
+ "trainingInProgress": "Модель в данный момент обучается",
+ "noNewImages": "Нет новых изображений для обучения. Сначала классифицируйте больше изображений в наборе данных.",
+ "noChanges": "В наборе данных не было изменений с момента последнего обучения.",
+ "modelNotReady": "Модель не готова к обучению"
+ },
+ "none": "Нет"
+}
diff --git a/web/public/locales/ru/views/configEditor.json b/web/public/locales/ru/views/configEditor.json
index 73b566a08..0dd775b24 100644
--- a/web/public/locales/ru/views/configEditor.json
+++ b/web/public/locales/ru/views/configEditor.json
@@ -12,5 +12,7 @@
"savingError": "Ошибка сохранения конфигурации"
}
},
- "confirm": "Выйти без сохранения?"
+ "confirm": "Выйти без сохранения?",
+ "safeConfigEditor": "Редактор конфигурации (безопасный режим)",
+ "safeModeDescription": "Frigate находится в безопасном режиме из-за ошибки проверки конфигурации."
}
diff --git a/web/public/locales/ru/views/events.json b/web/public/locales/ru/views/events.json
index 6c8bebb6e..a506ea452 100644
--- a/web/public/locales/ru/views/events.json
+++ b/web/public/locales/ru/views/events.json
@@ -10,7 +10,11 @@
"empty": {
"alert": "Отсутствуют тревоги для просмотра",
"detection": "Отсутствуют обнаружения для просмотра",
- "motion": "Не найдено данных о движении"
+ "motion": "Не найдено данных о движении",
+ "recordingsDisabled": {
+ "title": "Запись должна быть включена",
+ "description": "Элементы обзора могут быть созданы для камеры только в том случае, если запись включена для этой камеры."
+ }
},
"timeline": "Таймлайн",
"timeline.aria": "Выбор таймлайна",
@@ -35,5 +39,30 @@
"selected": "{{count}} выбрано",
"selected_one": "{{count}} выбрано",
"selected_other": "{{count}} выбрано",
- "detected": "обнаружен"
+ "detected": "обнаружен",
+ "suspiciousActivity": "Подозрительная активность",
+ "threateningActivity": "Угрожающая активность",
+ "detail": {
+ "noDataFound": "Нет данных для просмотра",
+ "aria": "Переключить подробный режим просмотра",
+ "trackedObject_one": "{{count}} объект",
+ "trackedObject_other": "{{count}} объекта",
+ "noObjectDetailData": "Данные о деталях объекта недоступны.",
+ "label": "Деталь",
+ "settings": "Настройки подробного просмотра",
+ "alwaysExpandActive": {
+ "title": "Всегда раскрывать активный",
+ "desc": "Всегда раскрывать сведения об объекте активного элемента обзора, если они доступны."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Отслеживаемая точка",
+ "clickToSeek": "Перейти к этому моменту"
+ },
+ "zoomIn": "Увеличить",
+ "zoomOut": "Отдалить",
+ "select_all": "Всё",
+ "normalActivity": "Нормальный",
+ "needsReview": "Требуется ревью",
+ "securityConcern": "Вопрос безопасности"
}
diff --git a/web/public/locales/ru/views/explore.json b/web/public/locales/ru/views/explore.json
index 63f6c2867..8431293fd 100644
--- a/web/public/locales/ru/views/explore.json
+++ b/web/public/locales/ru/views/explore.json
@@ -48,12 +48,16 @@
"success": {
"updatedSublabel": "Успешно обновлена дополнительная метка.",
"updatedLPR": "Номерной знак успешно обновлён.",
- "regenerate": "Новое описание запрошено у {{provider}}. В зависимости от скорости работы вашего провайдера, генерация нового описания может занять некоторое время."
+ "regenerate": "Новое описание запрошено у {{provider}}. В зависимости от скорости работы вашего провайдера, генерация нового описания может занять некоторое время.",
+ "audioTranscription": "Запрос на расшифровку аудио успешно отправлен. В зависимости от скорости вашего сервера Frigate, расшифровка может занять некоторое время.",
+ "updatedAttributes": "Атрибуты успешно обновлены."
},
"error": {
"updatedSublabelFailed": "Не удалось обновить дополнительную метку: {{errorMessage}}",
"updatedLPRFailed": "Не удалось обновить номерной знак: {{errorMessage}}",
- "regenerate": "Не удалось запросить новое описание у {{provider}}: {{errorMessage}}"
+ "regenerate": "Не удалось запросить новое описание у {{provider}}: {{errorMessage}}",
+ "audioTranscription": "Не удалось запросить транскрипцию аудио: {{errorMessage}}",
+ "updatedAttributesFailed": "Не удалось обновить атрибуты: {{errorMessage}}"
}
}
},
@@ -98,6 +102,17 @@
"regenerateFromThumbnails": "Перегенерировать из миниатюры",
"snapshotScore": {
"label": "Оценка снимка"
+ },
+ "score": {
+ "label": "Оценка"
+ },
+ "editAttributes": {
+ "title": "Редактировать атрибуты",
+ "desc": "Выберите атрибуты классификации для этого {{label}}"
+ },
+ "attributes": "Атрибуты классификации",
+ "title": {
+ "label": "Заголовок"
}
},
"trackedObjectDetails": "Детали объекта",
@@ -105,7 +120,9 @@
"details": "детали",
"snapshot": "снимок",
"video": "видео",
- "object_lifecycle": "жизненный цикл объекта"
+ "object_lifecycle": "жизненный цикл объекта",
+ "thumbnail": "миниатюра",
+ "tracking_details": "подробности отслеживания"
},
"objectLifecycle": {
"title": "Жизненный цикл объекта",
@@ -183,16 +200,38 @@
},
"deleteTrackedObject": {
"label": "Удалить этот отслеживаемый объект"
+ },
+ "addTrigger": {
+ "label": "Добавить триггер",
+ "aria": "Добавить триггер для этого отслеживаемого объекта"
+ },
+ "audioTranscription": {
+ "label": "Транскрибировать",
+ "aria": "Запросить аудиотранскрипцию"
+ },
+ "viewTrackingDetails": {
+ "label": "Просмотреть детали отслеживания",
+ "aria": "Показать детали отслеживания"
+ },
+ "showObjectDetails": {
+ "label": "Показать путь объекта"
+ },
+ "hideObjectDetails": {
+ "label": "Скрыть путь объекта"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Скачать чистый снимок",
+ "aria": "Скачать чистый снимок"
}
},
"dialog": {
"confirmDelete": {
"title": "Подтвердить удаление",
- "desc": "Удаление этого отслеживаемого объекта приведёт к удалению его снимка, всех сохранённых эмбеддингов и записей жизненного цикла. Сами записи в разделе История НЕ будут удалены.Рамки областей интереса
Ярко-зелёные рамки будут наложены на области интереса в кадре, которые отправляются детектору объектов.
" + }, + "paths": { + "title": "Пути", + "desc": "Показывать значимые точки пути отслеживаемого объекта", + "tips": "Пути
Линии и круги будут обозначать важные точки, которые отслеживаемый объект посетил в течение своего жизненного цикла.
" + }, + "openCameraWebUI": "Открыть веб-интерфейс {{camera}}", + "audio": { + "title": "Аудио", + "noAudioDetections": "Аудиообнаружений нет", + "score": "оценка", + "currentRMS": "Текущий RMS", + "currentdbFS": "Текущий dbFS" } }, "frigatePlus": { @@ -683,5 +768,495 @@ "success": "Настройки обогащений сохранены. Перезапустите Frigate, чтобы применить изменения.", "error": "Не удалось сохранить изменения: {{errorMessage}}" } + }, + "triggers": { + "documentTitle": "Триггеры", + "management": { + "title": "Триггеры", + "desc": "Управление триггерами для камеры {{camera}}. Используйте тип миниатюры для срабатывания по миниатюрам, похожим на выбранный отслеживаемый объект, и тип описания для срабатывания по описаниям, похожим на указанный вами текст." + }, + "addTrigger": "Добавить Триггер", + "table": { + "name": "Имя", + "type": "Тип", + "content": "Содержимое", + "threshold": "Порог", + "actions": "Действия", + "noTriggers": "Для этой камеры не настроены триггеры.", + "edit": "Редактировать", + "deleteTrigger": "Удалить триггер", + "lastTriggered": "Последний сработавший" + }, + "type": { + "thumbnail": "Миниатюра", + "description": "Описание" + }, + "actions": { + "alert": "Отметить как предупреждение", + "notification": "Отправить оповещение", + "sub_label": "Добавить подметку", + "attribute": "Добавить атрибут" + }, + "dialog": { + "createTrigger": { + "title": "Создать триггер", + "desc": "Создать триггер для камеры {{camera}}" + }, + "editTrigger": { + "title": "Изменить триггер", + "desc": "Изменить настройки триггера для камеры {{camera}}" + }, + "deleteTrigger": { + "title": "Удалить триггер", + "desc": "Вы уверены, что хотите удалить триггер {{triggerName}}? Это действие не может быть отменено." + }, + "form": { + "name": { + "title": "Имя", + "placeholder": "Назовите этот триггер", + "error": { + "minLength": "Поле должно содержать не менее 2 символов.", + "invalidCharacters": "Поле может содержать только буквы, цифры, символы подчеркивания и дефисы.", + "alreadyExists": "Триггер с таким именем уже существует для этой камеры." + }, + "description": "Введите уникальное имя или описание для идентификации этого триггера" + }, + "enabled": { + "description": "Включить или отключить этот триггер" + }, + "type": { + "title": "Тип", + "placeholder": "Выберите тип триггера", + "description": "Срабатывать при обнаружении похожего описания отслеживаемого объекта", + "thumbnail": "Срабатывать при обнаружении похожей миниатюры отслеживаемого объекта" + }, + "content": { + "title": "Содержимое", + "imagePlaceholder": "Выберите миниатюру", + "textPlaceholder": "Введите текстовое содержимое", + "imageDesc": "Отображаются только 100 последних миниатюр. Если вы не можете найти нужную миниатюру, просмотрите предыдущие объекты в разделе \"Обзор\" и настройте триггер оттуда через меню.", + "textDesc": "Введите текст, чтобы активировать это действие при обнаружении похожего описания отслеживаемого объекта.", + "error": { + "required": "Требуется содержимое." + } + }, + "threshold": { + "title": "Порог", + "error": { + "min": "Порог должен быть не менее 0", + "max": "Порог должен быть не более 1" + }, + "desc": "Установите порог схожести для этого триггера. Более высокое значение требует более точного совпадения для срабатывания триггера." + }, + "actions": { + "title": "Действия", + "desc": "По умолчанию Frigate отправляет MQTT-сообщение для всех триггеров. Подметки добавляют имя триггера к метке объекта. Атрибуты — это доступные для поиска метаданные, хранящиеся отдельно в метаданных отслеживаемого объекта.", + "error": { + "min": "Необходимо выбрать хотя бы одно действие." + } + }, + "friendly_name": { + "description": "Необязательное название или описание к этому триггеру", + "placeholder": "Название или описание триггера", + "title": "Понятное название" + } + } + }, + "toast": { + "success": { + "createTrigger": "Триггер {{name}} успешно создан.", + "updateTrigger": "Триггер {{name}} успешно обновлен.", + "deleteTrigger": "Триггер {{name}} успешно удален." + }, + "error": { + "createTriggerFailed": "Не удалось создать триггер: {{errorMessage}}", + "updateTriggerFailed": "Не удалось обновить триггер: {{errorMessage}}", + "deleteTriggerFailed": "Не удалось удалить триггер: {{errorMessage}}" + } + }, + "semanticSearch": { + "title": "Семантический поиск выключен", + "desc": "Для использования триггеров необходимо включить семантический поиск." + }, + "wizard": { + "title": "Создать триггер", + "step1": { + "description": "Настройте основные параметры вашего триггера." + }, + "step2": { + "description": "Настройте содержимое, которое будет активировать это действие." + }, + "step3": { + "description": "Настройте порог и действия для этого триггера." + }, + "steps": { + "nameAndType": "Имя и тип", + "configureData": "Настроить данные", + "thresholdAndActions": "Порог и действия" + } + } + }, + "cameraWizard": { + "title": "Добавить камеру", + "description": "Следуйте инструкциям ниже, чтобы добавить новую камеру в вашу установку Frigate.", + "steps": { + "nameAndConnection": "Имя и подключение", + "streamConfiguration": "Конфигурация потока", + "validationAndTesting": "Проверка и тестирование", + "probeOrSnapshot": "Проверка или снимок" + }, + "save": { + "success": "Новая камера {{cameraName}} успешно сохранена.", + "failure": "Ошибка при сохранении {{cameraName}}." + }, + "testResultLabels": { + "resolution": "Разрешение", + "video": "Видео", + "audio": "Аудио", + "fps": "Кадры в секунду (FPS)" + }, + "commonErrors": { + "noUrl": "Пожалуйста, укажите корректный URL потока", + "testFailed": "Тест потока не удался: {{error}}" + }, + "step1": { + "description": "Введите параметры вашей камеры и выберите: автоматическое определение или ручной выбор производителя.", + "cameraName": "Имя камеры", + "cameraNamePlaceholder": "Например, front_door или Обзор заднего двора", + "host": "Хост/IP-адрес", + "port": "Порт", + "username": "Имя пользователя", + "usernamePlaceholder": "Необязательно", + "password": "Пароль", + "passwordPlaceholder": "Необязательно", + "selectTransport": "Выберите транспортный протокол", + "cameraBrand": "Бренд камеры", + "selectBrand": "Выберите бренд камеры для шаблона URL", + "customUrl": "Пользовательский URL потока", + "brandInformation": "Информация о бренде", + "brandUrlFormat": "Для камер с форматом RTSP-URL вида: {{exampleUrl}}", + "customUrlPlaceholder": "rtsp://имя_пользователя:пароль@хост:порт/путь", + "testConnection": "Проверить соединение", + "testSuccess": "Соединение успешно установлено!", + "testFailed": "Проверка соединения не удалась. Проверьте введённые данные и попробуйте снова.", + "streamDetails": "Детали потока", + "warnings": { + "noSnapshot": "Не удалось получить снимок из настроенного потока." + }, + "errors": { + "brandOrCustomUrlRequired": "Выберите бренд камеры с указанием хоста/IP или выберите \"Другое\" и укажите пользовательский URL", + "nameRequired": "Необходимо указать имя камеры", + "nameLength": "Имя камеры должно содержать не более 64 символов", + "invalidCharacters": "Имя камеры содержит недопустимые символы", + "nameExists": "Имя камеры уже используется", + "brands": { + "reolink-rtsp": "RTSP от Reolink не рекомендуется. Включите HTTP в настройках камеры и перезапустите мастер настройки камеры." + }, + "customUrlRtspRequired": "Пользовательские URL должны начинаться с \"rtsp://\". Для потоков камер, не использующих RTSP, требуется ручная настройка." + }, + "docs": { + "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras" + }, + "testing": { + "probingMetadata": "Проверка метаданных камеры…", + "fetchingSnapshot": "Получение снимка с камеры…" + }, + "connectionSettings": "Настройки подключения", + "detectionMethod": "Метод обнаружения потока", + "onvifPort": "Порт ONVIF", + "probeMode": "Проверить камеру", + "manualMode": "Ручной выбор", + "detectionMethodDescription": "Проверьте камеру с помощью ONVIF (если поддерживается) для поиска URL потоков камеры или вручную выберите бренд камеры для использования предопределённых URL. Чтобы ввести пользовательский RTSP URL, выберите ручной метод и выберите \"Другое\".", + "onvifPortDescription": "Для камер, поддерживающих ONVIF, это обычно 80 или 8080.", + "useDigestAuth": "Использовать digest-аутентификацию", + "useDigestAuthDescription": "Использовать HTTP digest-аутентификацию для ONVIF. Некоторые камеры могут требовать отдельное имя пользователя/пароль ONVIF вместо стандартного пользователя администратора." + }, + "step2": { + "description": "Проверьте камеру на наличие доступных потоков или настройте параметры вручную в зависимости от выбранного метода обнаружения.", + "streamsTitle": "Потоки камеры", + "addStream": "Добавить поток", + "addAnotherStream": "Добавить ещё один поток", + "streamTitle": "Поток {{number}}", + "streamUrl": "URL потока", + "streamUrlPlaceholder": "rtsp://имя_пользователя:пароль@хост:порт/путь", + "url": "URL", + "resolution": "Разрешение", + "selectResolution": "Выберите разрешение", + "quality": "Качество", + "selectQuality": "Выберите качество", + "roles": "Роли", + "roleLabels": { + "detect": "Обнаружение объектов", + "record": "Запись", + "audio": "Аудио" + }, + "testStream": "Проверить соединение", + "testSuccess": "Проверка соединения успешна!", + "testFailed": "Проверка соединения не удалась. Проверьте введённые данные и попробуйте снова.", + "testFailedTitle": "Проверка не удалась", + "streamDetails": "Детали потока", + "probing": "Проверка камеры…", + "retry": "Повторить", + "testing": { + "probingMetadata": "Проверка метаданных камеры…", + "fetchingSnapshot": "Получение снимка с камеры…" + }, + "probeFailed": "Не удалось проверить камеру: {{error}}", + "probingDevice": "Проверка устройства…", + "probeSuccessful": "Проверка успешна", + "probeError": "Ошибка проверки", + "probeNoSuccess": "Проверка не удалась", + "deviceInfo": "Информация об устройстве", + "manufacturer": "Производитель", + "model": "Модель", + "firmware": "Прошивка", + "profiles": "Профили", + "ptzSupport": "Поддержка PTZ", + "autotrackingSupport": "Поддержка автотрекинга", + "presets": "Предустановки", + "rtspCandidates": "Кандидаты RTSP", + "rtspCandidatesDescription": "Следующие RTSP URL были найдены при проверке камеры. Проверьте соединение, чтобы просмотреть метаданные потока.", + "noRtspCandidates": "RTSP URL не найдены для камеры. Ваши учётные данные могут быть неверными, или камера может не поддерживать ONVIF или метод, используемый для получения RTSP URL. Вернитесь назад и введите RTSP URL вручную.", + "candidateStreamTitle": "Кандидат {{number}}", + "useCandidate": "Использовать", + "uriCopy": "Копировать", + "uriCopied": "URI скопирован в буфер обмена", + "testConnection": "Проверить соединение", + "toggleUriView": "Нажмите, чтобы переключить полный вид URI", + "connected": "Подключено", + "notConnected": "Не подключено", + "errors": { + "hostRequired": "Требуется хост/IP-адрес" + } + }, + "step3": { + "description": "Настройте роли потоков и добавьте дополнительные потоки для вашей камеры.", + "streamsTitle": "Потоки камеры", + "addStream": "Добавить поток", + "addAnotherStream": "Добавить ещё поток", + "streamTitle": "Поток {{number}}", + "streamUrl": "URL потока", + "streamUrlPlaceholder": "rtsp://имя_пользователя:пароль@хост:порт/путь", + "selectStream": "Выбрать поток", + "searchCandidates": "Поиск кандидатов…", + "noStreamFound": "Поток не найден", + "url": "URL", + "resolution": "Разрешение", + "selectResolution": "Выберите разрешение", + "quality": "Качество", + "selectQuality": "Выберите качество", + "roles": "Роли", + "roleLabels": { + "detect": "Обнаружение объектов", + "record": "Запись", + "audio": "Аудио" + }, + "testStream": "Проверить соединение", + "testSuccess": "Тест потока выполнен успешно!", + "testFailed": "Тест потока не пройден", + "testFailedTitle": "Тест не пройден", + "connected": "Подключено", + "notConnected": "Не подключено", + "featuresTitle": "Функции", + "go2rtc": "Уменьшить количество подключений к камере", + "detectRoleWarning": "Хотя бы один поток должен иметь роль \"detect\" для продолжения.", + "rolesPopover": { + "title": "Роли потоков", + "detect": "Основной поток для обнаружения объектов.", + "record": "Сохраняет сегменты видеопотока на основе настроек конфигурации.", + "audio": "Поток для обнаружения на основе аудио." + }, + "featuresPopover": { + "title": "Функции потоков", + "description": "Использовать рестриминг go2rtc для уменьшения количества подключений к камере." + } + }, + "step4": { + "description": "Финальная проверка и анализ перед сохранением новой камеры. Подключите каждый поток перед сохранением.", + "validationTitle": "Проверка потоков", + "connectAllStreams": "Подключить все потоки", + "reconnectionSuccess": "Переподключение успешно.", + "reconnectionPartial": "Некоторые потоки не удалось переподключить.", + "streamUnavailable": "Предпросмотр потока недоступен", + "reload": "Перезагрузить", + "connecting": "Подключение…", + "streamTitle": "Поток {{number}}", + "valid": "Действителен", + "failed": "Не удалось", + "notTested": "Не проверен", + "connectStream": "Подключить", + "connectingStream": "Подключение", + "disconnectStream": "Отключить", + "estimatedBandwidth": "Расчётная пропускная способность", + "roles": "Роли", + "ffmpegModule": "Использовать режим совместимости потоков", + "ffmpegModuleDescription": "Если поток не загружается после нескольких попыток, попробуйте включить это. При включении Frigate будет использовать модуль ffmpeg с go2rtc. Это может обеспечить лучшую совместимость с некоторыми потоками камер.", + "none": "Нет", + "error": "Ошибка", + "streamValidated": "Поток {{number}} успешно проверен", + "streamValidationFailed": "Проверка потока {{number}} не удалась", + "saveAndApply": "Сохранить новую камеру", + "saveError": "Неверная конфигурация. Пожалуйста, проверьте настройки.", + "issues": { + "title": "Проверка потоков", + "videoCodecGood": "Видеокодек: {{codec}}.", + "audioCodecGood": "Аудиокодек: {{codec}}.", + "resolutionHigh": "Разрешение {{resolution}} может привести к увеличению использования ресурсов.", + "resolutionLow": "Разрешение {{resolution}} может быть слишком низким для надёжного обнаружения мелких объектов.", + "noAudioWarning": "Аудио не обнаружено для этого потока, записи не будут содержать аудио.", + "audioCodecRecordError": "Для поддержки аудио в записях требуется аудиокодек AAC.", + "audioCodecRequired": "Для поддержки обнаружения аудио требуется аудиопоток.", + "restreamingWarning": "Уменьшение количества подключений к камере для потока записи может немного увеличить использование CPU.", + "brands": { + "reolink-rtsp": "RTSP от Reolink не рекомендуется. Включите HTTP в настройках прошивки камеры и перезапустите мастер.", + "reolink-http": "HTTP потоки Reolink должны использовать FFmpeg для лучшей совместимости. Включите 'Использовать режим совместимости потоков' для этого потока." + }, + "dahua": { + "substreamWarning": "Подпоток 1 заблокирован на низком разрешении. Многие камеры Dahua / Amcrest / EmpireTech поддерживают дополнительные подпотоки, которые необходимо включить в настройках камеры. Рекомендуется проверить и использовать эти потоки, если они доступны." + }, + "hikvision": { + "substreamWarning": "Подпоток 1 заблокирован на низком разрешении. Многие камеры Hikvision поддерживают дополнительные подпотоки, которые необходимо включить в настройках камеры. Рекомендуется проверить и использовать эти потоки, если они доступны." + } + } + } + }, + "roles": { + "addRole": "Добавить роль", + "table": { + "role": "Роль", + "cameras": "Камеры", + "actions": "Действия", + "editCameras": "Редактировать камеры", + "deleteRole": "Удалить роль", + "noRoles": "Пользовательских ролей не найдено." + }, + "toast": { + "success": { + "createRole": "Роль {{role}} успешно создана", + "updateCameras": "Камеры обновлены для роли {{role}}", + "deleteRole": "Роль {{role}} успешно удалена", + "userRolesUpdated_one": "{{count}} пользователь, назначенный на эту роль, был обновлён до роли 'наблюдатель', которая имеет доступ ко всем камерам.", + "userRolesUpdated_few": "{{count}} пользователя, назначенных на эту роль, были обновлены до роли 'наблюдатель', которая имеет доступ ко всем камерам.", + "userRolesUpdated_many": "{{count}} пользователей, назначенных на эту роль, были обновлены до роли 'наблюдатель', которая имеет доступ ко всем камерам." + }, + "error": { + "createRoleFailed": "Не удалось создать роль: {{errorMessage}}", + "updateCamerasFailed": "Не удалось обновить камеры: {{errorMessage}}", + "deleteRoleFailed": "Не удалось удалить роль: {{errorMessage}}", + "userUpdateFailed": "Не удалось обновить роли пользователей: {{errorMessage}}" + } + }, + "dialog": { + "createRole": { + "title": "Создать новую роль", + "desc": "Добавьте новую роль и укажите права доступа к камерам." + }, + "editCameras": { + "title": "Редактировать камеры роли", + "desc": "Обновите доступ к камерам для роли {{role}}." + }, + "deleteRole": { + "title": "Удалить роль", + "desc": "Это действие нельзя отменить. Это действие навсегда удалит роль и назначит всех пользователей с этой ролью на роль 'наблюдатель', что даст наблюдателю доступ ко всем камерам.", + "warn": "Вы уверены, что хотите удалить {{role}}?", + "deleting": "Удаление…" + }, + "form": { + "role": { + "title": "Название роли", + "placeholder": "Введите название роли", + "desc": "Разрешены только буквы, цифры, точки и подчёркивания.", + "roleIsRequired": "Требуется название роли", + "roleOnlyInclude": "Название роли может содержать только буквы, цифры, . или _", + "roleExists": "Роль с таким названием уже существует." + }, + "cameras": { + "title": "Камеры", + "desc": "Выберите камеры, к которым эта роль имеет доступ. Необходимо выбрать хотя бы одну камеру.", + "required": "Необходимо выбрать хотя бы одну камеру." + } + } + }, + "management": { + "title": "Управление ролями наблюдателя", + "desc": "Управление пользовательскими ролями наблюдателя и их правами доступа к камерам для этого экземпляра Frigate." + } + }, + "cameraManagement": { + "title": "Управление камерами", + "addCamera": "Добавить новую камеру", + "editCamera": "Редактировать камеру:", + "selectCamera": "Выбрать камеру", + "backToSettings": "Вернуться к настройкам камеры", + "streams": { + "title": "Включить / Отключить камеры", + "desc": "Временно отключить камеру до перезапуска Frigate. Отключение камеры полностью останавливает обработку потоков этой камеры в Frigate. Обнаружение, запись и отладка будут недоступны.annotation_offset.",
+ "documentation": "Prečítajte si dokumentáciu ",
+ "millisecondsToOffset": "Milisekundy na posunutie detekcie anotácií. Predvolené: 0",
+ "tips": "TIP: Predstavte si klip udalosti, v ktorom osoba kráča zľava doprava. Ak je ohraničujúci rámček časovej osi udalosti stále naľavo od osoby, hodnota by sa mala znížiť. Podobne, ak osoba kráča zľava doprava a ohraničujúci rámček je stále pred ňou, hodnota by sa mala zvýšiť.",
+ "toast": {
+ "success": "Odsadenie anotácie pre {{camera}} bolo uložené do konfiguračného súboru. Reštartujte Frigate, aby sa zmeny prejavili."
+ }
+ }
+ },
+ "carousel": {
+ "previous": "Predchádzajúca snímka",
+ "next": "Ďalšia snímka"
+ }
+ },
+ "itemMenu": {
+ "downloadVideo": {
+ "label": "Stiahnut video",
+ "aria": "Stiahnite si video"
+ },
+ "downloadSnapshot": {
+ "label": "Stiahnite si snímok",
+ "aria": "Stiahnite si snímok"
+ },
+ "viewObjectLifecycle": {
+ "label": "Pozrieť životný cyklus objektu",
+ "aria": "Životný cyklus objektu"
+ },
+ "findSimilar": {
+ "label": "Nájsť podobné",
+ "aria": "Nájdite podobné sledované objekty"
+ },
+ "addTrigger": {
+ "label": "Pridať spúšťač",
+ "aria": "Pridať spúšťač pre tento sledovaný objekt"
+ },
+ "audioTranscription": {
+ "label": "Prepisovať",
+ "aria": "Požiadajte o prepis zvuku"
+ },
+ "submitToPlus": {
+ "label": "Odoslať na Frigate+",
+ "aria": "Odoslať na Frigate Plus"
+ },
+ "viewInHistory": {
+ "label": "Zobraziť v histórii",
+ "aria": "Zobraziť v histórii"
+ },
+ "deleteTrackedObject": {
+ "label": "Odstrániť tento sledovaný objekt"
+ },
+ "showObjectDetails": {
+ "label": "Zobraziť cestu objektu"
+ },
+ "hideObjectDetails": {
+ "label": "Skryť cestu objektu"
+ },
+ "viewTrackingDetails": {
+ "label": "Zobraziť podrobnosti sledovania",
+ "aria": "Zobraziť podrobnosti o sledovaní"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Stiahnuť čistý snapshot",
+ "aria": "Stiahnuť čistý snapshot"
+ }
+ },
+ "dialog": {
+ "confirmDelete": {
+ "title": "Potvrdiť zmazanie",
+ "desc": "Odstránením tohto sledovaného objektu sa odstráni snímka, všetky uložené vložené prvky a všetky súvisiace položky s podrobnosťami o sledovaní. Zaznamenané zábery tohto sledovaného objektu v zobrazení História NEBUDÚ odstránené.: {{effectiveRetainMode}}, takže táto nahrávka na požiadanie uchová iba segmenty s nastavením {{effectiveRetainModeName}}."
+ },
+ "editLayout": {
+ "label": "Upraviť rozloženie",
+ "group": {
+ "label": "Upraviť skupinu kamier"
+ },
+ "exitEdit": "Ukončiť úpravy"
+ },
+ "noCameras": {
+ "title": "Nie sú konfigurované žiadne kamery",
+ "description": "Začnite tým, že pripojíte kameru do Frigate.",
+ "buttonText": "Pridať kameru",
+ "restricted": {
+ "title": "Žiadne kamery k dispozícii",
+ "description": "Nemáte povolenie na zobrazenie akýchkoľvek kamier v tejto skupine."
+ }
+ },
+ "snapshot": {
+ "takeSnapshot": "Stiahnite si okamžité snímky",
+ "noVideoSource": "Žiadny zdroj videa k dispozícii pre snapshot.",
+ "captureFailed": "Nepodarilo sa zachytiť snímku.",
+ "downloadStarted": "Sťahovanie snímky sa začalo."
}
}
diff --git a/web/public/locales/sk/views/search.json b/web/public/locales/sk/views/search.json
index cc567af26..a368ca123 100644
--- a/web/public/locales/sk/views/search.json
+++ b/web/public/locales/sk/views/search.json
@@ -41,6 +41,32 @@
"minSpeedMustBeLessOrEqualMaxSpeed": "Hodnota „min_speed“ musí byť menšia alebo rovná hodnote „max_speed“.",
"maxSpeedMustBeGreaterOrEqualMinSpeed": "Hodnota „max_speed“ musí byť väčšia alebo rovná hodnote „min_speed“."
}
+ },
+ "tips": {
+ "title": "Ako používať textové filtre",
+ "desc": {
+ "text": "Filtre vám pomôžu zúžiť výsledky vyhľadávania. Tu je postup, ako ich použiť vo vstupnom poli:",
+ "step1": "Zadajte názov kľúča filtra, za ktorým nasleduje dvojbodka (napr. „kamery:“).",
+ "step2": "Vyberte hodnotu z návrhov alebo zadajte vlastnú.",
+ "step3": "Použite viacero filtrov tak, že ich pridáte jeden po druhom s medzerou medzi nimi.",
+ "step4": "Filtre dátumu (pred: a po:) používajú formát {{DateFormat}}.",
+ "step5": "Filter časového rozsahu používa formát {{exampleTime}}.",
+ "step6": "Filtre odstránite kliknutím na „x“ vedľa nich.",
+ "exampleLabel": "Príklad:"
+ }
+ },
+ "header": {
+ "currentFilterType": "Hodnoty filtra",
+ "noFilters": "Filtre",
+ "activeFilters": "Aktívne filtre"
}
+ },
+ "similaritySearch": {
+ "title": "Vyhľadávanie podobností",
+ "active": "Vyhľadávanie podobnosti je aktívne",
+ "clear": "Jasné vyhľadávanie podobnosti"
+ },
+ "placeholder": {
+ "search": "Hľadať…"
}
}
diff --git a/web/public/locales/sk/views/settings.json b/web/public/locales/sk/views/settings.json
index 27013c197..900236606 100644
--- a/web/public/locales/sk/views/settings.json
+++ b/web/public/locales/sk/views/settings.json
@@ -2,14 +2,16 @@
"documentTitle": {
"default": "Nastavenia - Frigate",
"authentication": "Nastavenie autentifikácie- Frigate",
- "camera": "Nastavenia fotoaparátu – Frigate",
+ "camera": "Nastavenia Kamier– Frigate",
"enrichments": "Nastavenia obohatenia – Frigate",
"masksAndZones": "Editor masky a zón - Frigate",
"motionTuner": "Ladič detekcie pohybu - Frigate",
"object": "Ladenie - Frigate",
- "general": "Všeobecné nastavenia – Frigate",
+ "general": "UI nastavenia – Frigate",
"frigatePlus": "Nastavenia Frigate+ – Frigate",
- "notifications": "Nastavenia upozornení – Frigate"
+ "notifications": "Nastavenia upozornení – Frigate",
+ "cameraManagement": "Manažment kamier - Frigate",
+ "cameraReview": "Nastavenie kamier - Frigate"
},
"menu": {
"ui": "Uživaťelské rozohranie",
@@ -20,7 +22,11 @@
"debug": "Ladenie",
"users": "Uživatelia",
"notifications": "Notifikacie",
- "frigateplus": "Frigate+"
+ "frigateplus": "Frigate+",
+ "triggers": "Spúšťače",
+ "roles": "Roly",
+ "cameraManagement": "Manažment",
+ "cameraReview": "Recenzia"
},
"dialog": {
"unsavedChanges": {
@@ -33,7 +39,7 @@
"noCamera": "Žiadna Kamera"
},
"general": {
- "title": "Hlavné nastavenia",
+ "title": "UI nastavenia",
"liveDashboard": {
"title": "Živý Dashboard",
"automaticLiveView": {
@@ -43,12 +49,1162 @@
"playAlertVideos": {
"label": "Prehrať videá s upozornením",
"desc": "Predvolene sa nedávne upozornenia na paneli Živé vysielanie prehrávajú ako krátke cyklické videá. Túto možnosť vypnite, ak chcete zobrazovať iba statický obrázok nedávnych upozornení na tomto zariadení/prehliadači."
+ },
+ "displayCameraNames": {
+ "label": "Vždy Zobraziť názvy kamier",
+ "desc": "Vždy zobrazujte názvy kamier v čipe na ovládacom paneli živého náhľadu z viacerých kamier."
+ },
+ "liveFallbackTimeout": {
+ "label": "Časový limit",
+ "desc": "Keď je kamerový vysoko kvalitný živý stream nedostupný, prejdite späť na režim nízkej kvality. Predvolené: 3."
}
},
"storedLayouts": {
"title": "Uložené rozloženia",
"desc": "Rozloženie kamier v skupine kamier je možné presúvať/zmeniť jeho veľkosť. Pozície sú uložené v lokálnom úložisku vášho prehliadača.",
"clearAll": "Vymazať všetky rozloženia"
+ },
+ "cameraGroupStreaming": {
+ "title": "Nastavenia streamovania skupiny kamier",
+ "desc": "Nastavenia streamovania pre každú skupinu kamier sú uložené v lokálnom úložisku vášho prehliadača.",
+ "clearAll": "Vymazať všetky nastavenia streamovania"
+ },
+ "recordingsViewer": {
+ "title": "Prehliadač nahrávok",
+ "defaultPlaybackRate": {
+ "label": "Predvolená rýchlosť prehrávania",
+ "desc": "Predvolená rýchlosť prehrávania nahrávok."
+ }
+ },
+ "calendar": {
+ "title": "Kalendár",
+ "firstWeekday": {
+ "label": "Prvý pracovný deň",
+ "desc": "Deň, kedy začínajú týždne v kalendári kontroly.",
+ "sunday": "Nedeľa",
+ "monday": "Pondelok"
+ }
+ },
+ "toast": {
+ "success": {
+ "clearStoredLayout": "Uložené rozloženie pre {{cameraName}} bolo vymazané",
+ "clearStreamingSettings": "Nastavenia streamovania pre všetky skupiny kamier boli vymazané."
+ },
+ "error": {
+ "clearStoredLayoutFailed": "Nepodarilo sa vymazať uložené rozloženie: {{errorMessage}}",
+ "clearStreamingSettingsFailed": "Nepodarilo sa vymazať nastavenia streamovania: {{errorMessage}}"
+ }
+ }
+ },
+ "enrichments": {
+ "title": "Nastavenia obohatení",
+ "unsavedChanges": "Zmeny nastavení neuložených obohatení",
+ "birdClassification": {
+ "title": "Klasifikácia vtákov",
+ "desc": "Klasifikácia vtákov identifikuje známe vtáky pomocou kvantizovaného modelu Tensorflow. Keď je známy vták rozpoznaný, jeho bežný názov sa pridá ako podoznačenie (sub_label). Tieto informácie sú zahrnuté v používateľskom rozhraní, filtroch, ako aj v oznámeniach."
+ },
+ "semanticSearch": {
+ "title": "Sémantické vyhľadávanie",
+ "desc": "Sémantické vyhľadávanie vo Frigate vám umožňuje nájsť sledované objekty v rámci vašich recenzovaných položiek pomocou samotného obrázka, textového popisu definovaného používateľom alebo automaticky vygenerovaného popisu.",
+ "reindexNow": {
+ "label": "Preindexovať teraz",
+ "desc": "Reindexovanie obnoví vložené súbory pre všetky sledované objekty. Tento proces beží na pozadí a môže maximálne zaťažiť váš procesor a trvať pomerne dlho v závislosti od počtu sledovaných objektov, ktoré máte.",
+ "confirmTitle": "Potvrďte opätovné indexovanie",
+ "confirmDesc": "Naozaj chcete preindexovať všetky sledované vložené objekty? Tento proces bude bežať na pozadí, ale môže maximálne zaťažiť váš procesor a trvať pomerne dlho. Priebeh si môžete pozrieť na stránke Preskúmať.",
+ "confirmButton": "Preindexovať",
+ "success": "Reindexovanie sa úspešne spustilo.",
+ "alreadyInProgress": "Reindexovanie už prebieha.",
+ "error": "Nepodarilo sa spustiť reindexáciu: {{errorMessage}}"
+ },
+ "modelSize": {
+ "label": "Veľkosť modelu",
+ "desc": "Veľkosť modelu použitého pre vkladanie sémantického vyhľadávania.",
+ "small": {
+ "title": "malý",
+ "desc": "Použitie funkcie small využíva kvantizovanú verziu modelu, ktorá spotrebuje menej pamäte RAM a beží rýchlejšie na CPU s veľmi zanedbateľným rozdielom v kvalite vkladania."
+ },
+ "large": {
+ "title": "veľký",
+ "desc": "Použitie parametra large využíva celý model Jina a v prípade potreby sa automaticky spustí na GPU."
+ }
+ }
+ },
+ "faceRecognition": {
+ "title": "Rozpoznávanie tváre",
+ "desc": "Rozpoznávanie tváre umožňuje priradiť ľuďom mená a po rozpoznaní ich tváre Frigate priradí meno osoby ako podštítok. Tieto informácie sú zahrnuté v používateľskom rozhraní, filtroch, ako aj v upozorneniach.",
+ "modelSize": {
+ "label": "Veľkosť modelu",
+ "desc": "Veľkosť modelu použitého na rozpoznávanie tváre.",
+ "small": {
+ "title": "malý",
+ "desc": "Použitie funkcie small využíva model vkladania tvárí FaceNet, ktorý efektívne beží na väčšine procesorov."
+ },
+ "large": {
+ "title": "veľký",
+ "desc": "Použitie funkcie large využíva model vkladania tvárí ArcFace a v prípade potreby sa automaticky spustí na grafickom procesore."
+ }
+ }
+ },
+ "licensePlateRecognition": {
+ "title": "Rozpoznávanie ŠPZ",
+ "desc": "Frigate dokáže rozpoznávať evidenčné čísla vozidiel a automaticky pridávať detekované znaky do poľa recognized_license_plate alebo známy názov ako podradený štítok k objektom typu car. Bežným prípadom použitia môže byť čítanie evidenčných čísel áut vchádzajúcich na príjazdovú cestu alebo áut prechádzajúcich po ulici."
+ },
+ "restart_required": "Vyžaduje sa reštart (zmenené nastavenia obohatenia)",
+ "toast": {
+ "success": "Nastavenia obohatenia boli uložené. Reštartujte Frigate, aby sa zmeny prejavili.",
+ "error": "Nepodarilo sa uložiť zmeny konfigurácie: {{errorMessage}}"
+ }
+ },
+ "camera": {
+ "title": "Nastavenie kamier",
+ "streams": {
+ "title": "Streamy",
+ "desc": "Dočasne deaktivujte kameru, kým sa Frigate nereštartuje. Deaktivácia kamery úplne zastaví spracovanie streamov z tejto kamery aplikáciou Frigate. Detekcia, nahrávanie a ladenie nebudú k dispozícii.
Poznámka: Toto nezakáže restreamy go2rtc."
+ },
+ "review": {
+ "title": "Recenzia",
+ "desc": "Dočasne povoliť/zakázať upozornenia a detekcie pre túto kameru, kým sa Frigate nereštartuje. Po zakázaní sa nebudú generovať žiadne nové položky kontroly. ",
+ "alerts": "Upozornenia ",
+ "detections": "Detekcie "
+ },
+ "object_descriptions": {
+ "title": "Generatívne popisy objektov umelej inteligencie",
+ "desc": "Dočasne povoliť/zakázať generatívne popisy objektov AI pre túto kameru. Ak je táto funkcia zakázaná, pre sledované objekty na tejto kamere sa nebudú vyžadovať popisy generované AI."
+ },
+ "review_descriptions": {
+ "title": "Popisy generatívnej umelej inteligencie",
+ "desc": "Dočasne povoliť/zakázať generatívne popisy kontroly pomocou umelej inteligencie pre túto kameru. Ak je táto funkcia zakázaná, popisy generované umelou inteligenciou sa nebudú vyžadovať pre položky kontroly v tejto kamere."
+ },
+ "reviewClassification": {
+ "title": "Preskúmať klasifikáciu",
+ "desc": "Frigate kategorizuje položky recenzií ako Upozornenia a Detekcie. Predvolene sa všetky objekty typu osoba a auto považujú za Upozornenia. Kategorizáciu položiek recenzií môžete spresniť konfiguráciou požadovaných zón pre ne.",
+ "noDefinedZones": "Pre túto kameru nie sú definované žiadne zóny.",
+ "objectAlertsTips": "Všetky objekty {{alertsLabels}} na {{cameraName}} sa zobrazia ako Upozornenia.",
+ "zoneObjectAlertsTips": "Všetky objekty {{alertsLabels}} detekované v {{zone}} na {{cameraName}} budú zobrazené ako Upozornenia.",
+ "objectDetectionsTips": "Všetky objekty {{detectionsLabels}}, ktoré nie sú zaradené do kategórie {{cameraName}}, sa zobrazia ako detekcie bez ohľadu na to, v ktorej zóne sa nachádzajú.",
+ "zoneObjectDetectionsTips": {
+ "text": "Všetky objekty {{detectionsLabels}}, ktoré nie sú zaradené do kategórie {{zone}} na kamere {{cameraName}}, budú zobrazené ako detekcie.",
+ "notSelectDetections": "Všetky objekty typu {{detectionsLabels}} detekované v zóne {{zone}} na kamere {{cameraName}}, ktoré nie sú zaradené do kategórie Upozornenia, sa zobrazia ako Detekcie bez ohľadu na to, v ktorej zóne sa nachádzajú.",
+ "regardlessOfZoneObjectDetectionsTips": "Všetky objekty {{detectionsLabels}}, ktoré nie sú zaradené do kategórie {{cameraName}}, sa zobrazia ako detekcie bez ohľadu na to, v ktorej zóne sa nachádzajú."
+ },
+ "unsavedChanges": "Neuložené nastavenia klasifikácie recenzií pre {{camera}}",
+ "selectAlertsZones": "Vyberte podobné sledované objekty",
+ "selectDetectionsZones": "Vyberte zóny pre detekcie",
+ "limitDetections": "Obmedziť detekciu na konkrétne zóny",
+ "toast": {
+ "success": "Konfigurácia klasifikácie bola uložená. Reštartujte Frigate, aby sa zmeny prejavili."
+ }
+ },
+ "addCamera": "Pridať novu kameru",
+ "editCamera": "Upraviť kameru:",
+ "selectCamera": "Vyberte kameru",
+ "backToSettings": "Späť na nastavenia kamery",
+ "cameraConfig": {
+ "add": "Pridať kameru",
+ "edit": "Upraviť kameru",
+ "description": "Konfigurovať nastavenia kamery, vrátane vstupov streamu a rolí.",
+ "name": "Názov kamery",
+ "nameRequired": "Názov kamery je povinný",
+ "nameLength": "Názov kamery musí mať menej ako 24 znakov.",
+ "namePlaceholder": "napr. predné dvere",
+ "enabled": "Povoliť",
+ "ffmpeg": {
+ "inputs": "Vstupné streamy",
+ "path": "Cesta streamu",
+ "pathRequired": "Cesta k streamu je povinná",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Roly",
+ "rolesRequired": "Je vyžadovaná aspoň jedna rola",
+ "rolesUnique": "Každá rola (audio, detekcia, záznam) môže byť priradená iba k jednému streamu",
+ "addInput": "Pridať vstupný stream",
+ "removeInput": "Odobrať vstupný stream",
+ "inputsRequired": "Je vyžadovaný aspoň jeden vstupný stream"
+ },
+ "toast": {
+ "success": "Kamera {{cameraName}} bola úspešne uložená"
+ }
+ }
+ },
+ "masksAndZones": {
+ "filter": {
+ "all": "Všetky Masky a Zóny"
+ },
+ "restart_required": "Vyžadovaný reštart (masky/zóny boli zmenené)",
+ "toast": {
+ "success": {
+ "copyCoordinates": "Súradnice pre {{polyName}} skopírované do schránky."
+ },
+ "error": {
+ "copyCoordinatesFailed": "Nemohol kopírovať súradnice na klipboard."
+ }
+ },
+ "form": {
+ "polygonDrawing": {
+ "error": {
+ "mustBeFinished": "Kreslenie polygónu musí byť pred uložením dokončené."
+ },
+ "removeLastPoint": "Odobrať posledný bod",
+ "reset": {
+ "label": "Vymazať všetky body"
+ },
+ "snapPoints": {
+ "true": "Prichytávať body",
+ "false": "Neprichytávať body"
+ },
+ "delete": {
+ "title": "Potvrdiť Zmazanie",
+ "desc": "Naozaj chcete zmazať {{type}}{{name}}?",
+ "success": "{{name}} bolo zmazané."
+ }
+ },
+ "zoneName": {
+ "error": {
+ "mustBeAtLeastTwoCharacters": "Názov Zóny musia mať minimálne 2 znaky.",
+ "mustNotBeSameWithCamera": "Názov Zóny nesmie byť rovnaký ako názov kamery.",
+ "alreadyExists": "Zóna s rovnakým názvom pri tejto kamere už existuje.",
+ "mustNotContainPeriod": "Názov zóny nesmie obsahovať bodky.",
+ "hasIllegalCharacter": "Názov zóny obsahuje zakázané znaky.",
+ "mustHaveAtLeastOneLetter": "Názov zóny musí mať aspoň jedno písmeno."
+ }
+ },
+ "distance": {
+ "error": {
+ "text": "Vzdialenosť musí byť väčšia alebo rovná 0.1.",
+ "mustBeFilled": "Na použitie odhadu rýchlosti musia byť vyplnené všetky polia pre vzdialenosť."
+ }
+ },
+ "inertia": {
+ "error": {
+ "mustBeAboveZero": "Zotrvačnosť musí byť väčšia ako 0."
+ }
+ },
+ "loiteringTime": {
+ "error": {
+ "mustBeGreaterOrEqualZero": "Doba zotrvania musí byť väčšia alebo rovná nule."
+ }
+ },
+ "speed": {
+ "error": {
+ "mustBeGreaterOrEqualTo": "Prahová hodnota rýchlosti musí byť väčšia alebo rovná 0,1."
+ }
+ }
+ },
+ "zones": {
+ "label": "Zóny",
+ "documentTitle": "Upraviť Zónu - Frigate",
+ "desc": {
+ "title": "Zóny umožňujú definovať konkrétnu oblasť v zábere, vďaka čomu je možné určiť, či sa objekt nachádza v danej oblasti alebo nie.",
+ "documentation": "Dokumentácia"
+ },
+ "clickDrawPolygon": "Kliknite pre kreslenie polygónu na obrázku.",
+ "name": {
+ "title": "Meno",
+ "inputPlaceHolder": "Zadajte meno…",
+ "tips": "Názov musí mať aspoň 2 znaky, musí mať aspoň jedno písmeno a nesmie byť názvom kamery alebo inej zóny."
+ },
+ "inertia": {
+ "title": "Zotrvačnosť",
+ "desc": "Určuje, po koľkých snímkach strávených v zóne je objekt považovaný za prítomný v tejto zóne.Predvolená hodnota: 3"
+ },
+ "loiteringTime": {
+ "title": "Doba zotrvania",
+ "desc": "Nastavuje minimálnu dobu v sekundách, počas ktorej musí byť objekt v zóne, aby došlo k aktivácii.Predvolená hodnota: 0"
+ },
+ "objects": {
+ "title": "Objekty",
+ "desc": "Zoznam objektov, na ktoré sa táto zóna vzťahuje."
+ },
+ "allObjects": "Všetky Objekty",
+ "speedEstimation": {
+ "title": "Odhad rýchlosti",
+ "desc": "Povoliť odhad rýchlosti pre objekty v tejto zóne. Zóna musí mať presne 4 body.",
+ "lineADistance": "Vzdialenosť linky A ({{unit}})",
+ "lineBDistance": "Vzdialenosť linky B ({{unit}})",
+ "lineCDistance": "Vzdialenosť linky C ({{unit}})",
+ "lineDDistance": "Vzdialenosť linky D ({{unit}})"
+ },
+ "speedThreshold": {
+ "title": "Prah rýchlosti ({{unit}})",
+ "desc": "Určuje minimálnu rýchlosť, pri ktorej sú objekty v tejto zóne zohľadnené.",
+ "toast": {
+ "error": {
+ "pointLengthError": "Odhad rýchlosti bol pre túto zónu deaktivovaný. Zóny s odhadom rýchlosti musia mať presne 4 body.",
+ "loiteringTimeError": "Pokiaľ má zóna nastavenú dobu zotrvania väčšiu ako 0, neodporúča sa používať odhad rýchlosti."
+ }
+ }
+ },
+ "toast": {
+ "success": "Zóna {{zoneName}} bola uložená. Reštartujte Frigate pre aplikovanie zmien."
+ },
+ "add": "Pridať zónu",
+ "edit": "Upraviť zónu",
+ "point_one": "{{count}}bod",
+ "point_few": "{{count}}body",
+ "point_other": "{{count}}bodov"
+ },
+ "motionMasks": {
+ "label": "Maska Detekcia pohybu",
+ "documentTitle": "Editovať Masku Detekcia pohybu - Frigate",
+ "desc": {
+ "title": "Masky detekcie pohybu slúžia na zabránenie nežiaducim typom pohybu v spustení detekcie. Príliš rozsiahle maskovanie však môže sťažiť sledovanie objektov.",
+ "documentation": "Dokumentácia"
+ },
+ "add": "Nová Maska Detekcia pohybu",
+ "edit": "Upraviť Masku Detekcia pohybu",
+ "context": {
+ "title": "Masky detekcie pohybu slúžia na zabránenie tomu, aby nežiaduce typy pohybu spúšťali detekciu (napríklad vetvy stromov alebo časové značky kamery). Masky detekcie pohybu by sa mali používať veľmi striedmo – príliš rozsiahle maskovanie môže sťažiť sledovanie objektov."
+ },
+ "point_one": "{{count}} bod",
+ "point_few": "{{count}} body",
+ "point_other": "{{count}} bodov",
+ "clickDrawPolygon": "Kliknutím nakreslíte polygón do obrázku.",
+ "polygonAreaTooLarge": {
+ "title": "Maska detekcie pohybu pokrýva {{polygonArea}}% záberu kamery. Príliš veľké masky detekcie pohybu nie sú odporúčané.",
+ "tips": "Masky detekcie pohybu nebránia detekcii objektov. Namiesto toho by ste mali použiť požadovanú zónu."
+ },
+ "toast": {
+ "success": {
+ "title": "{{polygonName}} bol uložený. Reštartujte Frigate pre aplikovanie zmien.",
+ "noName": "Maska Detekcia pohybu bola uložená. Reštartujte Frigate pre aplikovanie zmien."
+ }
+ }
+ },
+ "objectMasks": {
+ "label": "Masky Objektu",
+ "documentTitle": "Upraviť Masku Objektu - Frigate",
+ "desc": {
+ "title": "Masky filtrovania objektov slúžia na odfiltrovanie falošných detekcií daného typu objektu na základe jeho umiestnenia.",
+ "documentation": "Dokumentácia"
+ },
+ "add": "Pridať Masku Objektu",
+ "edit": "Upraviť Masku Objektu",
+ "context": "Masky filtrovania objektov slúžia na odfiltrovanie falošných poplachov konkrétneho typu objektu na základe jeho umiestnenia.",
+ "point_one": "{{count}}bod",
+ "point_few": "{{count}}body",
+ "point_other": "{{count}} bodov",
+ "clickDrawPolygon": "Kliknutím nakreslite polygón do obrázku.",
+ "objects": {
+ "title": "Objekty",
+ "desc": "Typ objektu, na ktorý sa táto maska objektu vzťahuje.",
+ "allObjectTypes": "Všetky typy objektov"
+ },
+ "toast": {
+ "success": {
+ "title": "{{polygonName}} bol uložený. Reštartujte Frigate pre aplikovanie zmien.",
+ "noName": "Maska Objektu bola uložená. Reštartujte Frigate pre aplikovanie zmien."
+ }
+ }
+ },
+ "motionMaskLabel": "Maska Detekcia pohybu {{number}}",
+ "objectMaskLabel": "Maska Objektu {{number}} {{label}}"
+ },
+ "motionDetectionTuner": {
+ "title": "Ladenie detekcie pohybu",
+ "unsavedChanges": "Neuložené zmeny ladenia detekcie pohybu {{camera}}",
+ "desc": {
+ "title": "Frigate používa detekciu pohybu ako prvú kontrolu na overenie, či sa v snímke deje niečo, čo stojí za ďalšiu analýzu pomocou detekcie objektov.",
+ "documentation": "Prečítajte si príručku Ladenie detekcie pohybu"
+ },
+ "Threshold": {
+ "title": "Prah",
+ "desc": "Prahová hodnota určuje, aká veľká zmena jasu pixelu je nutná, aby bol považovaný za pohyb. Predvolené: 30"
+ },
+ "contourArea": {
+ "title": "Obrysová Oblasť",
+ "desc": "Hodnota plochy obrysu sa používa na rozhodnutie, ktoré skupiny zmenených pixelov sa kvalifikujú ako pohyb. Predvolené: 10"
+ },
+ "improveContrast": {
+ "title": "Zlepšiť Kontrast",
+ "desc": "Zlepšiť kontrast pre tmavé scény Predvolené: ON"
+ },
+ "toast": {
+ "success": "Nastavenie detekcie pohybu bolo uložené."
+ }
+ },
+ "debug": {
+ "title": "Ladenie",
+ "detectorDesc": "Frigate používa vaše detektory {{detectors}} na detekciu objektov v streame vašich kamier.",
+ "desc": "Ladiace zobrazenie ukazuje sledované objekty a ich štatistiky v reálnom čase. Zoznam objektov zobrazuje časovo oneskorený prehľad detekovaných objektov.",
+ "openCameraWebUI": "Otvoriť webové rozhranie {{camera}}",
+ "debugging": "Ladenie",
+ "objectList": "Zoznam objektov",
+ "noObjects": "Žiadne objekty",
+ "audio": {
+ "title": "Zvuk",
+ "noAudioDetections": "Žiadne detekcia zvuku",
+ "score": "skóre",
+ "currentRMS": "Aktuálne RMS",
+ "currentdbFS": "Aktuálne dbFS"
+ },
+ "boundingBoxes": {
+ "title": "Ohraničujúce rámčeky",
+ "desc": "Zobraziť ohraničujúce rámčeky okolo sledovaných objektov",
+ "colors": {
+ "label": "Farby Ohraničujúcich Rámčekov Objektov",
+ "info": "Pri spustení bude každému objektovému štítku priradená iná farba. Tenká tmavo modrá čiara označuje, že objekt nie je v danom okamihu detekovaný. Tenká šedá čiara znamená, že objekt je detekovaný ako nehybný. Silná čiara je označovaná aktivované). "
+ }
+ },
+ "timestamp": {
+ "title": "Časová pečiatka",
+ "desc": "Prekryť obrázok časovou pečiatkou"
+ },
+ "zones": {
+ "title": "Zóny",
+ "desc": "Zobraziť obrys všetkých definovaných zón"
+ },
+ "mask": {
+ "title": "Masky detekcie pohybu",
+ "desc": "Zobraziť polygóny masiek detekcie pohybu"
+ },
+ "motion": {
+ "title": "Rámčeky detekcie pohybu",
+ "desc": "Zobraziť rámčeky okolo oblastí, kde bol detekovaný pohyb",
+ "tips": "Boxy pohybu
Červené boxy budú prekryté na miestach snímky, kde je práve detekovaný pohyb.
"
+ },
+ "regions": {
+ "title": "Regióny",
+ "desc": "Zobraziť rámček oblasti záujmu odoslaný do detektora objektov",
+ "tips": "Oblasti regiónov
Jasnozelené políčka budú prekrývať oblasti záujmu v zábere, ktoré sa odosielajú do detektora objektov.
"
+ },
+ "paths": {
+ "title": "Cesty",
+ "desc": "Zobraziť významné body dráhy sledovaného objektu",
+ "tips": "Cesty
Čiary a kruhy označujú významné body, ktorými sa sledovaný objekt počas svojho životného cyklu pohyboval.
"
+ },
+ "objectShapeFilterDrawing": {
+ "title": "Výkres filtra tvaru objektu",
+ "desc": "Nakreslite na obrázok obdĺžnik, aby ste zobrazili podrobnosti o ploche a pomere",
+ "tips": "Povolením tejto možnosti nakreslíte na obraze kamery obdĺžnik, ktorý zobrazuje jeho plochu a pomer strán. Tieto hodnoty sa potom dajú použiť na nastavenie parametrov filtra tvaru objektu vo vašej konfigurácii.",
+ "score": "Skóre",
+ "ratio": "Pomer",
+ "area": "Oblasť"
+ }
+ },
+ "cameraWizard": {
+ "title": "Pridať kameru",
+ "description": "Postupujte podľa pokynov nižšie a pridajte novú kameru na inštaláciu Frigate.",
+ "steps": {
+ "nameAndConnection": "Meno a pripojenie",
+ "streamConfiguration": "Konfigurácia prúdu",
+ "validationAndTesting": "Platnosť a testovanie",
+ "probeOrSnapshot": "Probe alebo Snapshot"
+ },
+ "save": {
+ "success": "Úspešne zachránil novú kameru {{cameraName}}.",
+ "failure": "Úspora chýb {{cameraName}}."
+ },
+ "testResultLabels": {
+ "resolution": "Rozlíšenie",
+ "video": "Video",
+ "audio": "Zvuk",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Uveďte platnú adresu streamu",
+ "testFailed": "Test Stream zlyhal: {{error}}"
+ },
+ "step1": {
+ "description": "Zadajte detaily kamery a vyskúšajte pripojenie.",
+ "cameraName": "Názov kamery",
+ "cameraNamePlaceholder": "e.g., front_door alebo Back Yard Prehľad",
+ "host": "Hostia / IP adresa",
+ "port": "Prístav",
+ "username": "Používateľské meno",
+ "usernamePlaceholder": "Voliteľné",
+ "password": "Heslo",
+ "passwordPlaceholder": "Voliteľné",
+ "selectTransport": "Vyberte dopravný protokol",
+ "cameraBrand": "Značka kamery",
+ "selectBrand": "Vyberte značku kamery pre URL šablónu",
+ "customUrl": "Vlastné Stream URL",
+ "brandInformation": "Informácie o značke",
+ "brandUrlFormat": "Pre kamery s formátom RTSP URL ako: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "testConnection": "Testovacie pripojenie",
+ "testSuccess": "Test pripojenia úspešný!",
+ "testFailed": "Test pripojenia zlyhal. Skontrolujte svoj vstup a skúste to znova.",
+ "streamDetails": "Detaily vysielania",
+ "warnings": {
+ "noSnapshot": "Nemožno načítať snímku z konfigurovaného vysielania."
+ },
+ "errors": {
+ "brandOrCustomUrlRequired": "Buď vyberte značku kamery s hostiteľom / IP alebo si vyberte \"Iný\" s vlastnou URL",
+ "nameRequired": "Názov kamery je povinný",
+ "nameLength": "Názov kamery musí byť 64 znakov alebo menej",
+ "invalidCharacters": "Názov kamery obsahuje neplatné znaky",
+ "nameExists": "Názov kamery už existuje",
+ "brands": {
+ "reolink-rtsp": "Reolink RTSP sa neodporúča. Odporúča sa povoliť HTTP v nastavení kamery a reštartovať sprievodca kamery."
+ },
+ "customUrlRtspRequired": "Vlastné URL musia začať s \"rtsp / \"\". Manuálna konfigurácia je potrebná pre non-RTSP kamerové prúdy."
+ },
+ "docs": {
+ "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras"
+ },
+ "testing": {
+ "probingMetadata": "Skúmanie metadát kamery...",
+ "fetchingSnapshot": "Načítava sa snímka z kamery..."
+ },
+ "connectionSettings": "Nastavenie pripojenia",
+ "detectionMethod": "Stream Detekcia Metóda",
+ "onvifPort": "ONVIF Port",
+ "probeMode": "Probe kamera",
+ "manualMode": "Ručný výber",
+ "detectionMethodDescription": "Vyskúša cez ONVIF (ak je podporovaný) nájsť kamery streamové adresy, alebo ručne vyberte značku kamery a jej preddefinované URL. Ak chcete zadať vlastnú URL RTSP, vyberte manuálne zadanie a označte \"Ostatné\".",
+ "onvifPortDescription": "Pre kamery, ktoré podporujú ONVIF, to je zvyčajne 80 alebo 8080.",
+ "useDigestAuth": "Použite overenie súhrnu",
+ "useDigestAuthDescription": "Použite HTTP stráviteľné overenie pre ONVIF. Niektoré kamery môžu vyžadovať vyhradený ONVIF užívateľské meno/password namiesto štandardného správcu."
+ },
+ "step2": {
+ "description": "Vyhľadajte dostupné streamy z kamery alebo nakonfigurujte manuálne nastavenia na základe zvolenej metódy detekcie.",
+ "streamsTitle": "Kamerové prúdy",
+ "addStream": "Pridať Stream",
+ "addAnotherStream": "Pridať ďalší Stream",
+ "streamTitle": "Stream {{number}}",
+ "streamUrl": "Stream URL",
+ "streamUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "url": "URL",
+ "resolution": "Rozlíšenie",
+ "selectResolution": "Vyberte rozlíšenie",
+ "quality": "Kvalita",
+ "selectQuality": "Vyberte kvalitu",
+ "roles": "Roly",
+ "roleLabels": {
+ "detect": "Detekcia objektov",
+ "record": "Nahrávanie",
+ "audio": "Zvuk"
+ },
+ "testStream": "Testovacie pripojenie",
+ "testSuccess": "Test pripojenia bol úspešný!",
+ "testFailed": "Test pripojenia zlyhal. Skontrolujte zadané údaje a skúste to znova.",
+ "testFailedTitle": "Test Zlyhal",
+ "connected": "Pripojené",
+ "notConnected": "Nie je pripojený",
+ "featuresTitle": "Vlastnosti",
+ "go2rtc": "Znížte počet pripojení ku kamere",
+ "detectRoleWarning": "Aspoň jeden prúd musí mať \"detekt\" úlohu pokračovať.",
+ "rolesPopover": {
+ "title": "Roly streamu",
+ "detect": "Hlavné krmivo pre detekciu objektu.",
+ "record": "Ukladá segmenty video kanála na základe nastavení konfigurácie.",
+ "audio": "Kŕmenie pre detekciu zvuku."
+ },
+ "featuresPopover": {
+ "title": "Funkcie streamu",
+ "description": "Použite prekrytie go2rtc na zníženie pripojenia k fotoaparátu."
+ },
+ "streamDetails": "Detaily vysielania",
+ "probing": "Skúmajúca kamera...",
+ "retry": "Skúste to znova",
+ "testing": {
+ "probingMetadata": "Skúmanie metadát kamery...",
+ "fetchingSnapshot": "Načítava sa snímka z fotoaparátu..."
+ },
+ "probeFailed": "Nepodarilo sa otestovať kameru: {{error}}",
+ "probingDevice": "Snímacie zariadenie...",
+ "probeSuccessful": "Sonda úspešná",
+ "probeError": "Chyba sondy",
+ "probeNoSuccess": "Sonda neúspešná",
+ "deviceInfo": "Informácie o zariadení",
+ "manufacturer": "Výrobca",
+ "model": "Model",
+ "firmware": "Firmvér",
+ "profiles": "Profily",
+ "ptzSupport": "PTZ Podpora",
+ "autotrackingSupport": "Podpora automatického sledovania",
+ "presets": "Prestavby",
+ "rtspCandidates": "RTSP kandidátov",
+ "rtspCandidatesDescription": "Z kamery boli nájdené nasledujúce adresy URL RTSP. Otestujte pripojenie a zobrazte metadáta streamu.",
+ "noRtspCandidates": "Z kamery sa nenašli žiadne URL adresy RTSP. Vaše prihlasovacie údaje môžu byť nesprávne alebo kamera nepodporuje protokol ONVIF alebo metódu použitú na získanie URL adries RTSP. Vráťte sa späť a zadajte URL adresu RTSP manuálne.",
+ "candidateStreamTitle": "Kandidát {{number}}",
+ "useCandidate": "Použitie",
+ "uriCopy": "Kopírovať",
+ "uriCopied": "URI skopírované do schránky",
+ "testConnection": "Testovacie pripojenie",
+ "toggleUriView": "Kliknutím prepnete zobrazenie celého URI",
+ "errors": {
+ "hostRequired": "Vyžaduje sa hostiteľská/IP adresa"
+ }
+ },
+ "step3": {
+ "connectStream": "Pripojiť",
+ "connectingStream": "Pripája",
+ "disconnectStream": "Odpojiť",
+ "estimatedBandwidth": "Odhadovaná šírka pásma",
+ "roles": "Roly",
+ "none": "Žiadny",
+ "error": "Chyba",
+ "streamValidated": "Stream {{number}} úspešne overený",
+ "streamValidationFailed": "Stream {{number}} validácia zlyhala",
+ "saveAndApply": "Uložiť novú kameru",
+ "saveError": "Neplatná konfigurácia. Skontrolujte nastavenia.",
+ "issues": {
+ "title": "Stream Platnosť",
+ "videoCodecGood": "Kód videa {{codec}}.",
+ "audioCodecGood": "Audio kódc je {{codec}}.",
+ "noAudioWarning": "Žiadne audio zistené pre tento prúd, nahrávanie nebude mať audio.",
+ "audioCodecRecordError": "AAC audio kodek je potrebný na podporu audio v záznamoch.",
+ "audioCodecRequired": "Zvukový prúd je povinný podporovať detekciu zvuku.",
+ "restreamingWarning": "Zníženie pripojenia ku kamery pre rekordný prúd môže mierne zvýšiť využitie CPU.",
+ "dahua": {
+ "substreamWarning": "Substream 1 je uzamknutý na nízke rozlíšenie. Mnoho Dahua / Amcrest / EmpireTech kamery podporujú ďalšie podstreamy, ktoré musia byť povolené v nastavení kamery. Odporúča sa skontrolovať a využiť tie prúdy, ak je k dispozícii."
+ },
+ "hikvision": {
+ "substreamWarning": "Substream 1 je uzamknutý na nízke rozlíšenie. Mnoho Hikvision kamery podporujú ďalšie podstreamy, ktoré musia byť povolené v nastavení kamery. Odporúča sa skontrolovať a využiť tie prúdy, ak je k dispozícii."
+ },
+ "resolutionHigh": "Rozlíšenie {{resolution}} môže spôsobiť zvýšenú spotrebu zdrojov.",
+ "resolutionLow": "Rozlíšenie {{resolution}} môže byť príliš nízka pre spoľahlivú detekciu malých objektov."
+ },
+ "description": "Nakonfigurujte role streamov a pridajte ďalšie streamy pre vašu kameru.",
+ "validationTitle": "Stream Platnosť",
+ "connectAllStreams": "Pripojte všetky prúdy",
+ "reconnectionSuccess": "Opätovné pripojenie bolo úspešné.",
+ "reconnectionPartial": "Niektoré prúdy sa nepodarilo prepojiť.",
+ "streamUnavailable": "Ukážka streamu nie je k dispozícii",
+ "reload": "Znovu načítať",
+ "connecting": "Pripája...",
+ "streamTitle": "Stream {{number}}",
+ "valid": "Platné",
+ "failed": "Zlyhanie",
+ "notTested": "Netestované",
+ "streamsTitle": "Kamerové prúdy",
+ "addStream": "Pridať Stream",
+ "addAnotherStream": "Pridať ďalší Stream",
+ "streamUrl": "Stream URL",
+ "streamUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "selectStream": "Vyberte stream",
+ "searchCandidates": "Hľadať kandidátov...",
+ "noStreamFound": "Nenašiel sa žiadny stream",
+ "url": "URL",
+ "resolution": "Rozlíšenie",
+ "selectResolution": "Vyberte rozlíšenie",
+ "quality": "Kvalita",
+ "selectQuality": "Vyberte kvalitu",
+ "roleLabels": {
+ "detect": "Detekcia objektov",
+ "record": "Nahrávanie",
+ "audio": "Zvuk"
+ },
+ "testStream": "Testovanie pripojenia",
+ "testSuccess": "Stream test úspešné!",
+ "testFailed": "Stream test zlyhal",
+ "testFailedTitle": "Test Zlyhal",
+ "connected": "Pripojené",
+ "notConnected": "Nie je pripojený",
+ "featuresTitle": "Vlastnosti",
+ "go2rtc": "Znížte počet pripojení ku kamere",
+ "detectRoleWarning": "Aspoň jeden prúd musí mať \"detekt\" úlohu pokračovať.",
+ "rolesPopover": {
+ "title": "Roly streamu",
+ "detect": "Hlavné krmivo pre detekciu objektu.",
+ "record": "Ukladá segmenty video kanála na základe nastavení konfigurácie.",
+ "audio": "Kŕmenie pre detekciu zvuku."
+ },
+ "featuresPopover": {
+ "title": "Funkcie streamu",
+ "description": "Použite prekrytie go2rtc na zníženie pripojenia k fotoaparátu."
+ }
+ },
+ "step4": {
+ "description": "Záverečné overenie a analýza pred uložením nového fotoaparátu. Pripojte každý prúd pred uložením.",
+ "validationTitle": "Stream Platnosť",
+ "connectAllStreams": "Pripojte všetky prúdy",
+ "reconnectionSuccess": "Opätovné pripojenie bolo úspešné.",
+ "reconnectionPartial": "Niektoré prúdy sa nepodarilo prepojiť.",
+ "streamUnavailable": "Ukážka streamu nie je k dispozícii",
+ "reload": "Znovu načítať",
+ "connecting": "Pripája...",
+ "streamTitle": "Stream {{number}}",
+ "valid": "Platné",
+ "failed": "Zlyhanie",
+ "notTested": "Netestované",
+ "connectStream": "Pripojiť",
+ "connectingStream": "Pripája",
+ "disconnectStream": "Odpojiť",
+ "estimatedBandwidth": "Odhadovaná šírka pásma",
+ "roles": "Roly",
+ "ffmpegModule": "Použite režim kompatibility prúdu",
+ "ffmpegModuleDescription": "Ak sa stream nenačíta ani po niekoľkých pokusoch, skúste túto funkciu povoliť. Keď je táto funkcia povolená, Frigate použije modul ffmpeg s go2rtc. To môže poskytnúť lepšiu kompatibilitu s niektorými streammi z kamier.",
+ "none": "Žiadne",
+ "error": "Chyba",
+ "streamValidated": "Stream {{number}} úspešne overený",
+ "streamValidationFailed": "Stream {{number}} validácia zlyhala",
+ "saveAndApply": "Uložiť novú kameru",
+ "saveError": "Neplatná konfigurácia. Skontrolujte nastavenia.",
+ "issues": {
+ "title": "Platnosť Streamu",
+ "videoCodecGood": "Kód videa je {{codec}}.",
+ "audioCodecGood": "Audio kódc je {{codec}}.",
+ "resolutionHigh": "Rozlíšenie {{resolution}} môže spôsobiť zvýšenú spotrebu zdrojov.",
+ "resolutionLow": "Rozlíšenie {{resolution}} môže byť príliš nízka pre spoľahlivú detekciu malých objektov.",
+ "noAudioWarning": "Žiadne audio nebolo detekovane pre tento prúd, nahrávanie nebude mať audio.",
+ "audioCodecRecordError": "AAC audio kodek je potrebný na podporu audio v záznamoch.",
+ "audioCodecRequired": "Zvukový prúd je povinný podporovať detekciu zvuku.",
+ "restreamingWarning": "Zníženie pripojenia ku kamery pre rekordný prúd môže mierne zvýšiť využitie CPU.",
+ "brands": {
+ "reolink-rtsp": "Reolink RTSP sa neodporúča. Odporúča sa povoliť HTTP v nastavení kamery a reštartovať sprievodca kamery."
+ },
+ "dahua": {
+ "substreamWarning": "Čiastkový stream 1 je uzamknutý na nízke rozlíšenie. Mnoho kamier Dahua / Amcrest / EmpireTech podporuje ďalšie čiastkové streamy, ktoré je potrebné povoliť v nastaveniach kamery. Odporúča sa skontrolovať a využiť tieto streamy, ak sú k dispozícii."
+ },
+ "hikvision": {
+ "substreamWarning": "Čiastkový stream 1 je uzamknutý na nízke rozlíšenie. Mnoho kamier Hikvision podporuje ďalšie čiastkové streamy, ktoré je potrebné povoliť v nastaveniach kamery. Odporúča sa skontrolovať a využiť tieto streamy, ak sú k dispozícii."
+ }
+ }
+ }
+ },
+ "cameraManagement": {
+ "title": "Správa kamier",
+ "addCamera": "Pridať novu kameru",
+ "editCamera": "Upraviť kameru:",
+ "selectCamera": "Vyberte kameru",
+ "backToSettings": "Späť na nastavenia kamery",
+ "streams": {
+ "title": "Enable / Disable kamery",
+ "desc": "Dočasne deaktivujte kameru, kým sa Frigate nereštartuje. Deaktivácia kamery úplne zastaví spracovanie streamov z tejto kamery aplikáciou Frigate. Detekcia, nahrávanie a ladenie nebudú k dispozícii.
Poznámka: Toto nezakáže restreamy go2rtc."
+ },
+ "cameraConfig": {
+ "add": "Pridať kameru",
+ "edit": "Upraviť kameru",
+ "description": "Konfigurovať nastavenia kamery, vrátane vstupov streamu a rolí.",
+ "name": "Názov kamery",
+ "nameRequired": "Názov kamery je povinný",
+ "nameLength": "Názov kamery musí byť menšia ako 64 znakov.",
+ "namePlaceholder": "e.g., predne_dvere alebo Prehľad Záhrady",
+ "enabled": "Povoliť",
+ "ffmpeg": {
+ "inputs": "Vstupné streamy",
+ "path": "Cesta streamu",
+ "pathRequired": "Cesta k streamu je povinná",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Roly",
+ "rolesRequired": "Je vyžadovaná aspoň jedna rola",
+ "rolesUnique": "Každá rola (audio, detekcia, záznam) môže byť priradená iba k jednému streamu",
+ "addInput": "Pridať vstupný stream",
+ "removeInput": "Odobrať vstupný stream",
+ "inputsRequired": "Je vyžadovaný aspoň jeden vstupný stream"
+ },
+ "go2rtcStreams": "go2rtc Streamy",
+ "streamUrls": "Stream URLs",
+ "addUrl": "Pridať URL",
+ "addGo2rtcStream": "Pridať go2rtc Stream",
+ "toast": {
+ "success": "Kamera {{cameraName}} bola úspešne uložená"
+ }
+ }
+ },
+ "cameraReview": {
+ "title": "Nastavenie recenzie kamery",
+ "object_descriptions": {
+ "title": "Generatívne popisy objektov umelej inteligencie",
+ "desc": "Dočasne umožňujú/disable Generovať opisy objektu AI pre tento fotoaparát. Keď je zakázané, AI vygenerované popisy nebudú požiadané o sledovanie objektov na tomto fotoaparáte."
+ },
+ "review_descriptions": {
+ "title": "Popisy generatívnej umelej inteligencie",
+ "desc": "Dočasne povoliť/disable Genive AI opisy pre tento fotoaparát. Keď je zakázané, AI vygenerované popisy nebudú požiadané o preskúmanie položiek na tomto fotoaparáte."
+ },
+ "review": {
+ "title": "Recenzia",
+ "desc": "Dočasne umožňujú/disable upozornenia a detekcia pre tento fotoaparát až do reštartu Frigate. Pri vypnutých, nebudú vygenerované žiadne nové položky preskúmania. ",
+ "alerts": "Upozornenia ",
+ "detections": "Detekcie "
+ },
+ "reviewClassification": {
+ "title": "Preskúmať klasifikáciu",
+ "desc": "Frigate kategorizuje položky recenzií ako Upozornenia a Detekcie. Predvolene sa všetky objekty typu osoba a auto považujú za Upozornenia. Kategorizáciu položiek recenzií môžete spresniť konfiguráciou požadovaných zón pre ne.",
+ "noDefinedZones": "Pre túto kameru nie sú definované žiadne zóny.",
+ "objectAlertsTips": "Všetky objekty {{alertsLabels}} na {{cameraName}} sa zobrazia ako Upozornenia.",
+ "zoneObjectAlertsTips": "Všetky objekty {{alertsLabels}} detekované v {{zone}} na {{cameraName}} budú zobrazené ako Upozornenia.",
+ "objectDetectionsTips": "Všetky objekty {{detectionsLabels}}, ktoré nie sú zaradené do kategórie {{cameraName}}, sa zobrazia ako detekcie bez ohľadu na to, v ktorej zóne sa nachádzajú.",
+ "zoneObjectDetectionsTips": {
+ "text": "Všetky objekty {{detectionsLabels}}, ktoré nie sú zaradené do kategórie {{zone}} na kamere {{cameraName}}, budú zobrazené ako detekcie.",
+ "notSelectDetections": "Všetky objekty typu {{detectionsLabels}} detekované v zóne {{zone}} na kamere {{cameraName}}, ktoré nie sú zaradené do kategórie Upozornenia, sa zobrazia ako Detekcie bez ohľadu na to, v ktorej zóne sa nachádzajú.",
+ "regardlessOfZoneObjectDetectionsTips": "Všetky objekty {{detectionsLabels}}, ktoré nie sú zaradené do kategórie {{cameraName}}, sa zobrazia ako detekcie bez ohľadu na to, v ktorej zóne sa nachádzajú."
+ },
+ "unsavedChanges": "Nezaradené Nastavenie hodnotenia pre {{camera}}",
+ "selectAlertsZones": "Vyberte zóny pre upozornenia",
+ "selectDetectionsZones": "Vyberte zóny pre detekcie",
+ "limitDetections": "Obmedziť detekciu na konkrétne zóny",
+ "toast": {
+ "success": "Konfigurácia klasifikácie bola uložená. Reštartujte Frigate, aby sa zmeny prejavili."
+ }
+ }
+ },
+ "users": {
+ "title": "Používatelia",
+ "management": {
+ "title": "Správa používateľov",
+ "desc": "Spravovať používateľské účty tejto inštancie Frigate."
+ },
+ "addUser": "Pridať používateľa",
+ "updatePassword": "Aktualizovať heslo",
+ "toast": {
+ "success": {
+ "createUser": "Užívateľ {{user}} úspešne vytvorený",
+ "deleteUser": "Užívateľ {{user}} úspešne odobraný",
+ "updatePassword": "Heslo úspešne aktualizované.",
+ "roleUpdated": "Aktualizovaná rola pre používateľa {{user}}"
+ },
+ "error": {
+ "setPasswordFailed": "Nepodarilo sa uložiť heslo: {{errorMessage}}",
+ "createUserFailed": "Nepodarilo sa vytvoriť používateľa: {{errorMessage}}",
+ "deleteUserFailed": "Nepodarilo sa odstrániť používateľa: {{errorMessage}}",
+ "roleUpdateFailed": "Nepodarilo sa aktualizovať rolu: {{errorMessage}}"
+ }
+ },
+ "table": {
+ "username": "Používateľské meno",
+ "actions": "Akcie",
+ "role": "Rola",
+ "noUsers": "Nenašli sa žiadni používatelia.",
+ "changeRole": "Zmeniť rolu používateľa",
+ "password": "Heslo",
+ "deleteUser": "Odstrániť používateľa"
+ },
+ "dialog": {
+ "form": {
+ "user": {
+ "title": "Používateľské meno",
+ "desc": "Povolené sú iba písmená, čísla, bodky a podčiarkovníky.",
+ "placeholder": "Zadajte používateľské meno"
+ },
+ "password": {
+ "title": "Heslo",
+ "placeholder": "Zadajte heslo",
+ "confirm": {
+ "title": "Potvrdiť heslo",
+ "placeholder": "Potvrdiť heslo"
+ },
+ "strength": {
+ "title": "Sila hesla: ",
+ "weak": "Slabý",
+ "medium": "Stredná",
+ "strong": "Silný",
+ "veryStrong": "Veľmi silný"
+ },
+ "match": "Heslá sa zhodujú",
+ "notMatch": "Heslá sa nezhodujú"
+ },
+ "newPassword": {
+ "title": "Nové heslo",
+ "placeholder": "Zadajte nové heslo",
+ "confirm": {
+ "placeholder": "Znovu zadajte nové heslo"
+ }
+ },
+ "usernameIsRequired": "Vyžaduje sa používateľské meno",
+ "passwordIsRequired": "Heslo je povinné"
+ },
+ "createUser": {
+ "title": "Vytvorenie nového užívateľa",
+ "desc": "Pridajte nový používateľský účet a zadajte rolu pre prístup k oblastiam používateľského rozhrania Frigate.",
+ "usernameOnlyInclude": "Používateľské meno môže obsahovať iba písmená, číslice, . alebo _",
+ "confirmPassword": "Potvrďte svoje heslo"
+ },
+ "deleteUser": {
+ "title": "Odstrániť užívateľa",
+ "desc": "Túto akciu nie je možné vrátiť späť. Týmto sa natrvalo odstráni používateľský účet a odstránia sa všetky súvisiace údaje.",
+ "warn": "Naozaj chcete odstrániť používateľa {{username}}?"
+ },
+ "passwordSetting": {
+ "cannotBeEmpty": "Heslo nemôže byť prázdne",
+ "doNotMatch": "Heslá sa nezhodujú",
+ "updatePassword": "Aktualizácia hesla pre {{username}}",
+ "setPassword": "Nastaviť heslo",
+ "desc": "Vytvorte si silné heslo na zabezpečenie tohto účtu."
+ },
+ "changeRole": {
+ "title": "Zmeniť rolu používateľa",
+ "select": "Vyberte rolu",
+ "desc": "Aktualizovať povolenia pre používateľa {{username}}",
+ "roleInfo": {
+ "intro": "Vyberte príslušnú rolu pre tohto používateľa:",
+ "admin": "Správca",
+ "adminDesc": "Úplný prístup ku všetkým funkciám.",
+ "viewer": "Divák",
+ "viewerDesc": "Obmedzené iba na živé dashboardy, funkcie Review, Explore a Exports.",
+ "customDesc": "Vlastná rola so špecifickým prístupom k kamere."
+ }
+ }
+ }
+ },
+ "roles": {
+ "management": {
+ "title": "Správa roly diváka",
+ "desc": "Spravujte vlastné roly divákov a ich povolenia na prístup ku kamere pre túto inštanciu Frigate."
+ },
+ "addRole": "Pridať rolu",
+ "table": {
+ "role": "Rola",
+ "cameras": "Kamery",
+ "actions": "Akcie",
+ "noRoles": "Neboli nájdené žiadne vlastné role.",
+ "editCameras": "Editovať kamery",
+ "deleteRole": "Odstrániť rolu"
+ },
+ "toast": {
+ "success": {
+ "createRole": "Rola {{role}} bola úspešne vytvorená",
+ "updateCameras": "Kamery aktualizované pre rolu {{role}}",
+ "deleteRole": "Rola {{role}} bola úspešne odstránená",
+ "userRolesUpdated_one": "",
+ "userRolesUpdated_few": "",
+ "userRolesUpdated_other": "{{count}} užívatelia priradené tejto úlohe boli aktualizované pre \"viewer\", ktorý má prístup ku všetkým kamerám."
+ },
+ "error": {
+ "createRoleFailed": "Nepodarilo sa vytvoriť rolu: {{errorMessage}}",
+ "updateCamerasFailed": "Nepodarilo sa aktualizovať kamery: {{errorMessage}}",
+ "deleteRoleFailed": "Nepodarilo sa odstrániť rolu: {{errorMessage}}",
+ "userUpdateFailed": "Nepodarilo sa aktualizovať používateľské role: {{errorMessage}}"
+ }
+ },
+ "dialog": {
+ "createRole": {
+ "title": "Vytvoriť novú rolu",
+ "desc": "Pridajte novú úlohu a zadajte prístup k kamerám."
+ },
+ "editCameras": {
+ "title": "Editovať Rolu Kamery",
+ "desc": "Aktualizujte prístup k kamere pre rolu {{role}}."
+ },
+ "deleteRole": {
+ "title": "Odstrániť rolu",
+ "desc": "Túto akciu nie je možné vrátiť späť. Týmto sa rola natrvalo odstráni a všetci používatelia s touto rolou budú priradení k role „pozerač“, ktorá umožní divákovi prístup ku všetkým kamerám.",
+ "warn": "Ste si istí, že chcete odstrániť {{role}}?",
+ "deleting": "Odstraňuje sa..."
+ },
+ "form": {
+ "role": {
+ "title": "Názov role",
+ "placeholder": "Zadajte názov roly",
+ "desc": "Povolené sú iba písmená, čísla, bodky a podčiarkovníky.",
+ "roleIsRequired": "Vyžaduje sa názov roly",
+ "roleOnlyInclude": "Názov role môže obsahovať iba písmená, čísla, . alebo _",
+ "roleExists": "Úloha s týmto menom už existuje."
+ },
+ "cameras": {
+ "title": "Kamery",
+ "desc": "Vyberte kamery, ku ktorým má táto rola prístup. Vyžaduje sa aspoň jedna kamera.",
+ "required": "Aspoň jedna kamera musí byť vybraná."
+ }
+ }
+ }
+ },
+ "notification": {
+ "title": "Notifikacie",
+ "notificationSettings": {
+ "title": "Nastavenia notifikácií",
+ "desc": "Frigate dokáže natívne odosielať push notifikácie do vášho zariadenia, keď je spustený v prehliadači alebo nainštalovaný ako PWA."
+ },
+ "notificationUnavailable": {
+ "title": "Notifikacie su nedostupné",
+ "desc": "Webové push notifikácie vyžadujú zabezpečený kontext (https://…). Ide o obmedzenie prehliadača. Ak chcete používať notifikácie, pristupujte k Frigate bezpečne."
+ },
+ "globalSettings": {
+ "title": "Globálne nastavenia",
+ "desc": "Dočasne pozastaviť upozornenia pre konkrétne kamery na všetkých registrovaných zariadeniach."
+ },
+ "email": {
+ "title": "E-mail",
+ "placeholder": "e.g. príklad@email.com",
+ "desc": "Vyžaduje sa platný e-mail, ktorý bude použitý na upozornenie v prípade akýchkoľvek problémov so službou push."
+ },
+ "cameras": {
+ "title": "Kamery",
+ "noCameras": "K dispozícii nie sú žiadne kamery",
+ "desc": "Vyberte, na ktoré kamery umožňujú notifikácie."
+ },
+ "deviceSpecific": "Špecifické nastavenia zariadenia",
+ "registerDevice": "Registrovať toto zariadenie",
+ "unregisterDevice": "Zrušte registráciu tohto zariadenia",
+ "sendTestNotification": "Odoslať testovacie oznámenie",
+ "unsavedRegistrations": "Neuložené registrácie oznámení",
+ "unsavedChanges": "Neuložené zmeny upozornení",
+ "active": "Upozornenia sú aktívne",
+ "suspended": "Oznámenie pozastavuju {{time}}",
+ "suspendTime": {
+ "suspend": "Pozastaviť",
+ "5minutes": "Pozastaviť na 5 minút",
+ "10minutes": "Pozastaviť na 10 minút",
+ "30minutes": "Pozastaviť na 30 minút",
+ "1hour": "Pozastaviť na 1 hodinu",
+ "12hours": "Pozastaviť na 12 hodín",
+ "24hours": "Pozastaviť na 24 hodín",
+ "untilRestart": "Pozastaviť do reštartovania"
+ },
+ "cancelSuspension": "Zrušiť pozastavenie",
+ "toast": {
+ "success": {
+ "registered": "Úspešne zaregistrované pre upozornenia. Pred odoslaním akýchkoľvek upozornení (vrátane testovacieho upozornenia) je potrebné reštartovať Frigate.",
+ "settingSaved": "Nastavenie oznámenia boli uložené."
+ },
+ "error": {
+ "registerFailed": "Uloženie registrácie upozornenia zlyhalo."
+ }
+ }
+ },
+ "frigatePlus": {
+ "title": "Nastavenie Frigate+",
+ "apiKey": {
+ "title": "Frigate + API kľúč",
+ "validated": "Frigate + API kľúč je detekovaný a overený",
+ "notValidated": "Frigate + API kľúč nie je detekovaný alebo nie je overený",
+ "desc": "Frigate+ API kľúč umožňuje integráciu s Frigate+ služby.",
+ "plusLink": "Prečítajte si viac o Frigate+"
+ },
+ "snapshotConfig": {
+ "title": "Konfigurácia snímky",
+ "desc": "Odosielanie do Frigate+ vyžaduje, aby boli v konfigurácii povolené snímky aj snímky clean_copy.",
+ "cleanCopyWarning": "Niektoré kamery majú povolené snímky, ale voľba clean_copy je zakázaná. Pre možnosť odosielania snímok z týchto kamier do služby Frigate+ je nutné túto voľbu povoliť v konfigurácii snímok.",
+ "table": {
+ "camera": "Kamera",
+ "snapshots": "Snímky",
+ "cleanCopySnapshots": "clean_copy Snímky"
+ }
+ },
+ "modelInfo": {
+ "title": "Informácie o Modele",
+ "modelType": "Typ Modelu",
+ "trainDate": "Dátum Tréningu",
+ "baseModel": "Základný Model",
+ "plusModelType": {
+ "baseModel": "Základný Model",
+ "userModel": "Doladené"
+ },
+ "supportedDetectors": "Podporované Detektory",
+ "cameras": "Kamery",
+ "loading": "Načítavam informácie o modeli…",
+ "error": "Chyba načítania informácií o modeli",
+ "availableModels": "Dostupné Moduly",
+ "loadingAvailableModels": "Načítavam dostupné modely…",
+ "modelSelect": "Tu môžete vybrať dostupné modely zo služby Frigate+. Upozorňujeme, že je možné zvoliť iba modely kompatibilné s aktuálnou konfiguráciou detektora."
+ },
+ "unsavedChanges": "Neuložené zmeny nastavenia Frigate+",
+ "restart_required": "Vyžadovaný reštart (model Frigate+ zmenený)",
+ "toast": {
+ "success": "Nastavenia Frigate+ boli uložené. Reštartujte Frigate+ pre aplikovanie zmien.",
+ "error": "Chyba pri ukladaní zmien konfigurácie: {{errorMessage}}"
+ }
+ },
+ "triggers": {
+ "documentTitle": "Spúšťače",
+ "semanticSearch": {
+ "title": "Sémantické vyhľadávanie je vypnuté",
+ "desc": "Na používanie spúšťačov musí byť povolené sémantické vyhľadávanie."
+ },
+ "management": {
+ "title": "Spúšťače",
+ "desc": "Správa spúšťa {{camera}}. Použite typ miniatúry, aby ste spustili na podobných miniatúr na vybraných tracked objekt, a typ popisu, aby ste spustili podobné popisy na text, ktorý určíte."
+ },
+ "addTrigger": "Pridať Spúšťač",
+ "table": {
+ "name": "Meno",
+ "type": "Typ",
+ "content": "Obsah",
+ "threshold": "Prah",
+ "actions": "Akcie",
+ "noTriggers": "Pre túto kameru nie sú nakonfigurované žiadne spúšťače.",
+ "edit": "Upraviť",
+ "deleteTrigger": "Odstrániť spúšťač",
+ "lastTriggered": "Naposledy spustené"
+ },
+ "type": {
+ "thumbnail": "Náhľad",
+ "description": "Popis"
+ },
+ "actions": {
+ "notification": "Poslať upozornenie",
+ "sub_label": "Pridať vedľajší štítok",
+ "attribute": "Pridať atribút"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "Vytvoriť spúšťač",
+ "desc": "Vytvorte spúšť pre kameru {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Upraviť spúšťač",
+ "desc": "Upraviť nastavenia spúšťača na kamere {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Odstrániť spúšťač",
+ "desc": "Naozaj chcete odstrániť spúšťač {{triggerName}}? Túto akciu nie je možné vrátiť späť."
+ },
+ "form": {
+ "name": {
+ "title": "Meno",
+ "placeholder": "Zadajte meno pre spúšťača",
+ "description": "Zadajte jedinečné meno alebo popis na identifikáciu tohto spúšťania",
+ "error": {
+ "minLength": "Názov musí mať aspoň 2 znaky.",
+ "invalidCharacters": "Meno môže obsahovať iba písmená, číslice, podčiarkovníky a pomlčky.",
+ "alreadyExists": "Spúšťač s týmto názvom už pre túto kameru existuje."
+ }
+ },
+ "enabled": {
+ "description": "Povoliť alebo zakázať tento spúšťač"
+ },
+ "type": {
+ "title": "Typ",
+ "placeholder": "Vybrať typ spúšťača",
+ "description": "Spustiť, keď sa zistí podobný popis sledovaného objektu",
+ "thumbnail": "Spustiť, keď sa zistí podobná miniatúra sledovaného objektu"
+ },
+ "content": {
+ "title": "Obsah",
+ "imagePlaceholder": "Vyberte miniatúru",
+ "textPlaceholder": "Zadajte obsah textu",
+ "imageDesc": "Zobrazujú sa iba posledné 100 miniatúr. Ak nemôžete nájsť požadovanú miniatúru, prečítajte si skôr objekty v preskúmať a nastaviť spúšťací z ponuky tam.",
+ "textDesc": "Zadajte text, aby ste spustili túto akciu, keď je detekovaný podobný popis objektu.",
+ "error": {
+ "required": "Obsah je potrebný."
+ }
+ },
+ "threshold": {
+ "title": "Prah",
+ "desc": "Nastavte prah podobnosti pre tento spúšťač. Vyšší prah znamená, že na spustenie spúšťača je potrebná bližšia zhoda.",
+ "error": {
+ "min": "Threshold musí byť aspoň 0",
+ "max": "Threshold musí byť na väčšine 1"
+ }
+ },
+ "actions": {
+ "title": "Akcie",
+ "desc": "V predvolenom nastavení Frigate odosiela MQTT správu pre všetky spúšťače. Zvoľte dodatočnú akciu, ktorá sa má vykonať, keď sa tento spúšťač aktivuje.",
+ "error": {
+ "min": "Musí byť vybraná aspoň jedna akcia."
+ }
+ }
+ }
+ },
+ "wizard": {
+ "title": "Vytvoriť spúšťač",
+ "step1": {
+ "description": "Konfigurujte základné nastavenia pre vašu spúšť."
+ },
+ "step2": {
+ "description": "Nastavte obsah, ktorý spustí túto akciu."
+ },
+ "step3": {
+ "description": "Konfigurovať prah a akcie pre tento spúšťač."
+ },
+ "steps": {
+ "nameAndType": "Meno a typ",
+ "configureData": "Konfigurovať údaje",
+ "thresholdAndActions": "Prah a akcie"
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Spúšťač {{name}} bol úspešne vytvorený.",
+ "updateTrigger": "Spúšťač {{name}} bol úspešne aktualizovaný.",
+ "deleteTrigger": "Spúšťač {{name}} bol úspešne zmazaný."
+ },
+ "error": {
+ "createTriggerFailed": "Nepodarilo sa vytvoriť spúšťač: {{errorMessage}}",
+ "updateTriggerFailed": "Nepodarilo sa aktualizovať spúšťač: {{errorMessage}}",
+ "deleteTriggerFailed": "Nepodarilo sa zmazať spúšťač: {{errorMessage}}"
+ }
}
}
}
diff --git a/web/public/locales/sk/views/system.json b/web/public/locales/sk/views/system.json
index ea3a3927e..94afc9111 100644
--- a/web/public/locales/sk/views/system.json
+++ b/web/public/locales/sk/views/system.json
@@ -42,7 +42,8 @@
"inferenceSpeed": "Detekčná rýchlosť",
"temperature": "Detekčná teplota",
"cpuUsage": "Detektor využitia CPU",
- "memoryUsage": "Detektor využitia pamäte"
+ "memoryUsage": "Detektor využitia pamäte",
+ "cpuUsageInformation": "CPU použitý na prípravu vstupných a výstupných údajov do/z detekčných modelov. Táto hodnota nemeria využitie inferencie, a to ani v prípade použitia GPU alebo akcelerátora."
},
"hardwareInfo": {
"title": "Informácie o hardvéri",
@@ -52,9 +53,146 @@
"gpuDecoder": "GPU dekodér",
"gpuInfo": {
"vainfoOutput": {
- "title": "Výstup Vainfo"
+ "title": "Výstup Vainfo",
+ "returnCode": "Návratový kód: {{code}}",
+ "processOutput": "Výstup procesu:",
+ "processError": "Chyba procesu:"
+ },
+ "nvidiaSMIOutput": {
+ "title": "Výstup Nvidia SMI",
+ "name": "Meno: {{name}}",
+ "driver": "Vodič: {{driver}}",
+ "cudaComputerCapability": "Výpočtové možnosti CUDA: {{cuda_compute}}",
+ "vbios": "Informácie o VBiose: {{vbios}}"
+ },
+ "closeInfo": {
+ "label": "Zatvorte informácie o GPU"
+ },
+ "copyInfo": {
+ "label": "Kopírovať informácie o GPU"
+ },
+ "toast": {
+ "success": "Informácie o grafickej karte boli skopírované do schránky"
}
+ },
+ "npuUsage": "Použitie NPU",
+ "npuMemory": "Pamäť NPU",
+ "intelGpuWarning": {
+ "title": "Intel GPU Stats Upozornenie",
+ "message": "Štatistiky GPU nedostupné",
+ "description": "Toto je známa chyba v Štatistike správ Intel (intel_gpu_top) kde sa rozpadne a opakovane vráti používanie GPU 0% aj v prípadoch, keď hardvér detekcie objektov správne beží na (i)GPU. Toto nie je Frigate chyba. Môžete reštartovať a tak dočasne opraviť problém a potvrdiť, že GPU funguje správne. Toto nemá vplyv na výkon."
+ }
+ },
+ "otherProcesses": {
+ "title": "Iné procesy",
+ "processCpuUsage": "Proces využitia CPU",
+ "processMemoryUsage": "Procesné využitie pamäte"
+ }
+ },
+ "storage": {
+ "title": "Skladovanie",
+ "overview": "Prehľad",
+ "recordings": {
+ "title": "Nahrávky",
+ "tips": "Táto hodnota predstavuje celkové úložisko, ktoré používajú nahrávky v databáze Frigate. Frigate nesleduje využitie úložiska pre všetky súbory na vašom disku.",
+ "earliestRecording": "Najstaršia dostupná nahrávka:"
+ },
+ "shm": {
+ "title": "Alokácia SHM (zdieľanej pamäte)",
+ "warning": "Aktuálna veľkosť SHM {{total}}MB je príliš malá. Zvýšte ju aspoň na {{min_shm}}MB."
+ },
+ "cameraStorage": {
+ "title": "Úložisko kamery",
+ "camera": "Kamera",
+ "unusedStorageInformation": "Nepoužité informácie o úložisku",
+ "storageUsed": "Skladovanie",
+ "percentageOfTotalUsed": "Percento z celkového počtu",
+ "bandwidth": "Šírka pásma",
+ "unused": {
+ "title": "Nepoužité",
+ "tips": "Táto hodnota nemusí presne zodpovedať voľnému miestu dostupnému pre Frigate, ak máte na disku uložené aj iné súbory okrem nahrávok Frigate. Frigate nesleduje využitie úložiska mimo svojich nahrávok."
}
}
+ },
+ "cameras": {
+ "title": "Kamery",
+ "overview": "Prehľad",
+ "info": {
+ "aspectRatio": "pomer strán",
+ "cameraProbeInfo": "{{camera}} Informácie o sonde kamery",
+ "streamDataFromFFPROBE": "Údaje zo streamu sa získavajú pomocou príkazu ffprobe.",
+ "fetching": "Načítavajú sa údaje z kamery",
+ "stream": "Stream {{idx}}",
+ "video": "Video:",
+ "codec": "Kodek:",
+ "resolution": "Rozlíšenie:",
+ "fps": "FPS:",
+ "unknown": "Neznámy",
+ "audio": "Zvuk:",
+ "error": "Chyba: {{error}}",
+ "tips": {
+ "title": "Informácie o kamerovej sonde"
+ }
+ },
+ "framesAndDetections": "Rámy / Detekcie",
+ "label": {
+ "camera": "kamera",
+ "detect": "odhaliť",
+ "skipped": "preskočené",
+ "ffmpeg": "FFmpeg",
+ "capture": "zachytiť",
+ "cameraFfmpeg": "{{camName}} FFmpeg",
+ "cameraCapture": "zachytiť{{camName}}",
+ "cameraDetect": "Detekcia {{camName}}",
+ "overallFramesPerSecond": "celkový počet snímok za sekundu",
+ "overallDetectionsPerSecond": "celkový počet detekcií za sekundu",
+ "overallSkippedDetectionsPerSecond": "celkový počet vynechaných detekcií za sekundu",
+ "cameraFramesPerSecond": "{{camName}}snimky za sekundu",
+ "cameraDetectionsPerSecond": "{{camName}}detekcie za sekundu",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} vynechaných detekcií za sekundu"
+ },
+ "toast": {
+ "success": {
+ "copyToClipboard": "Dáta sondy boli skopírované do schránky."
+ },
+ "error": {
+ "unableToProbeCamera": "Nepodarilo sa overiť kameru: {{errorMessage}}"
+ }
+ }
+ },
+ "lastRefreshed": "Naposledy obnovené: ",
+ "stats": {
+ "ffmpegHighCpuUsage": "{{camera}} má vysoké využitie CPU vo formáte FFmpeg ({{ffmpegAvg}}%)",
+ "detectHighCpuUsage": "{{camera}} má vysoké využitie CPU pri detekcii ({{detectAvg}}%)",
+ "healthy": "Systém je zdravý",
+ "reindexingEmbeddings": "Preindexovanie vložených prvkov (dokončené na {{processed}} %)",
+ "cameraIsOffline": "{{camera}} je offline",
+ "detectIsSlow": "{{detect}} je pomalý ({{speed}} ms)",
+ "detectIsVerySlow": "{{detect}} je veľmi pomalý ({{speed}} ms)",
+ "shmTooLow": "Alokácia /dev/shm ({{total}} MB) by sa mala zvýšiť aspoň na {{min}} MB."
+ },
+ "enrichments": {
+ "title": "Obohatenia",
+ "infPerSecond": "Inferencie za sekundu",
+ "embeddings": {
+ "image_embedding": "Vkladanie obrázkov",
+ "text_embedding": "Vkladanie textu",
+ "face_recognition": "Rozpoznávanie tváre",
+ "plate_recognition": "Rozpoznávanie ŠPZ",
+ "image_embedding_speed": "Rýchlosť vkladania obrázkov",
+ "face_embedding_speed": "Rýchlosť vkladania tváre",
+ "face_recognition_speed": "Rýchlosť rozpoznávania tváre",
+ "plate_recognition_speed": "Rýchlosť rozpoznávania ŠPZ",
+ "text_embedding_speed": "Rýchlosť vkladania textu",
+ "yolov9_plate_detection_speed": "YOLOv9 rýchlosť detekcie ŠPZ",
+ "yolov9_plate_detection": "YOLOv9 Detekcia ŠPZ",
+ "review_description": "Popis recenzie",
+ "review_description_speed": "Popis recenzie Rýchlosťi",
+ "review_description_events_per_second": "Popis",
+ "object_description": "Popis objektu",
+ "object_description_speed": "Popis objektu Rýchlosť",
+ "object_description_events_per_second": "Popis objektu"
+ },
+ "averageInf": "Priemerný čas inferencie"
}
}
diff --git a/web/public/locales/sl/audio.json b/web/public/locales/sl/audio.json
index 31562e8c9..4c2bf4f8f 100644
--- a/web/public/locales/sl/audio.json
+++ b/web/public/locales/sl/audio.json
@@ -106,5 +106,40 @@
"piano": "Klavir",
"electric_piano": "Digitalni klavir",
"organ": "Orgle",
- "electronic_organ": "Digitalne orgle"
+ "electronic_organ": "Digitalne orgle",
+ "chant": "Spev",
+ "mantra": "Mantra",
+ "child_singing": "Otroško petje",
+ "synthetic_singing": "Sintetično petje",
+ "humming": "Brenčanje",
+ "groan": "Stok",
+ "grunt": "Godrnjanje",
+ "wheeze": "Zadihan izdih",
+ "gasp": "Glasen Vzdih",
+ "pant": "Sopihanje",
+ "snort": "Smrkanje",
+ "throat_clearing": "Odkašljevanje",
+ "sneeze": "Kihanje",
+ "sniff": "Vohljaj",
+ "chewing": "Žvečenje",
+ "biting": "Grizenje",
+ "gargling": "Grgranje",
+ "stomach_rumble": "Grmotanje v Želodcu",
+ "heart_murmur": "Šum na Srcu",
+ "chatter": "Klepetanje",
+ "yip": "Jip",
+ "growling": "Rjovenje",
+ "whimper_dog": "Pasje Cviljenje",
+ "oink": "Oink",
+ "gobble": "Zvok Purana",
+ "wild_animals": "Divje Živali",
+ "roaring_cats": "Rjoveče Mačke",
+ "roar": "Rjovenje Živali",
+ "squawk": "Krik",
+ "patter": "Klepetanje",
+ "croak": "Kvakanje",
+ "rattle": "Ropotanje",
+ "whale_vocalization": "Kitova Vokalizacija",
+ "plucked_string_instrument": "Trgani Godalni Instrument",
+ "snicker": "Hihitanje"
}
diff --git a/web/public/locales/sl/common.json b/web/public/locales/sl/common.json
index ff21c10ce..3df421bdf 100644
--- a/web/public/locales/sl/common.json
+++ b/web/public/locales/sl/common.json
@@ -51,7 +51,44 @@
"h": "{{time}}h",
"m": "{{time}}m",
"s": "{{time}}s",
- "yr": "le"
+ "yr": "{{time}}l.",
+ "formattedTimestamp": {
+ "12hour": "d MMM, h:mm:ss aaa",
+ "24hour": "d MMM, HH:mm:ss"
+ },
+ "formattedTimestamp2": {
+ "12hour": "dd/MM h:mm:ssa",
+ "24hour": "d MMM HH:mm:ss"
+ },
+ "formattedTimestampHourMinute": {
+ "12hour": "h:mm aaa",
+ "24hour": "HH:mm"
+ },
+ "formattedTimestampHourMinuteSecond": {
+ "12hour": "h:mm:ss aaa",
+ "24hour": "HH:mm:ss"
+ },
+ "formattedTimestampMonthDayHourMinute": {
+ "12hour": "d MMM, h:mm aaa",
+ "24hour": "d MMM, HH:mm"
+ },
+ "formattedTimestampMonthDayYear": {
+ "12hour": "d MMM, yyyy",
+ "24hour": "d MMM, yyyy"
+ },
+ "formattedTimestampMonthDayYearHourMinute": {
+ "12hour": "d MMM yyyy, h:mm aaa",
+ "24hour": "d MMM yyyy, HH:mm"
+ },
+ "formattedTimestampMonthDay": "d MMM",
+ "formattedTimestampFilename": {
+ "12hour": "dd-MM-yy-h-mm-ss-a",
+ "24hour": "dd-MM-yy-HH-mm-ss"
+ },
+ "invalidStartTime": "Napačen čas začetka",
+ "invalidEndTime": "Napačen čas konca",
+ "inProgress": "V teku",
+ "never": "Nikoli"
},
"menu": {
"live": {
@@ -67,9 +104,94 @@
},
"explore": "Brskanje",
"theme": {
- "nord": "Nord"
+ "nord": "Nord",
+ "label": "Teme",
+ "blue": "Modra",
+ "green": "Zelena",
+ "red": "Rdeča",
+ "highcontrast": "Visok Kontrast",
+ "default": "Privzeto"
},
- "review": "Pregled"
+ "review": "Pregled",
+ "system": "Sistem",
+ "systemMetrics": "Sistemske metrike",
+ "configuration": "Konfiguracija",
+ "systemLogs": "Sistemski dnevniki",
+ "settings": "Nastavitve",
+ "configurationEditor": "Urejevalnik Konfiguracije",
+ "languages": "Jeziki",
+ "language": {
+ "en": "English (angleščina)",
+ "es": "Español (španščina)",
+ "zhCN": "简体中文 (poenostavljena kitajščina)",
+ "hi": "हिन्दी (hindijščina)",
+ "fr": "Français (francoščina)",
+ "ar": "العربية (arabščina)",
+ "pt": "Português (portugalščina)",
+ "ru": "Русский (ruščina)",
+ "de": "Deutsch (nemščina)",
+ "ja": "日本語 (japonščina)",
+ "tr": "Türkçe (turščina)",
+ "it": "Italiano (italijanščina)",
+ "nl": "Nederlands (nizozemščina)",
+ "sv": "Svenska (švedščina)",
+ "cs": "Čeština (češčina)",
+ "nb": "Norsk Bokmål (norveščina, bokmal)",
+ "ko": "한국어 (korejščina)",
+ "vi": "Tiếng Việt (vietnamščina)",
+ "fa": "فارسی (perzijščina)",
+ "pl": "Polski (poljščina)",
+ "uk": "Українська (ukrajinščina)",
+ "he": "עברית (hebrejščina)",
+ "el": "Ελληνικά (grščina)",
+ "ro": "Română (romunščina)",
+ "hu": "Magyar (madžarščina)",
+ "fi": "Suomi (finščina)",
+ "da": "Dansk (danščina)",
+ "sk": "Slovenčina (slovaščina)",
+ "yue": "粵語 (kantonščina)",
+ "th": "ไทย (tajščina)",
+ "sr": "Српски (srbščina)",
+ "sl": "Slovenščina (Slovenščina )",
+ "bg": "Български (bulgarščina)",
+ "withSystem": {
+ "label": "Uporabi sistemske nastavitve za jezik"
+ },
+ "ptBR": "Português brasileiro (Brazilska portugalščina)",
+ "ca": "Català (Katalonščina)",
+ "lt": "Lietuvių (Litovščina)",
+ "gl": "Galego (Galicijščina)",
+ "id": "Bahasa Indonesia (Indonezijščina)",
+ "ur": "اردو (Urdujščina)"
+ },
+ "appearance": "Izgled",
+ "darkMode": {
+ "label": "Temni Način",
+ "light": "Svetlo",
+ "dark": "Temno",
+ "withSystem": {
+ "label": "Uporabi sistemske nastavitve za svetel ali temen način"
+ }
+ },
+ "withSystem": "Sistem",
+ "help": "Pomoč",
+ "documentation": {
+ "title": "Dokumentacija",
+ "label": "Frigate dokumentacija"
+ },
+ "restart": "Znova Zaženi Frigate",
+ "export": "Izvoz",
+ "faceLibrary": "Zbirka Obrazov",
+ "user": {
+ "title": "Uporabnik",
+ "account": "Račun",
+ "current": "Trenutni Uporabnik: {{user}}",
+ "anonymous": "anonimen",
+ "logout": "Odjava",
+ "setPassword": "Nastavi Geslo"
+ },
+ "uiPlayground": "UI Peskovnik",
+ "classification": "Klasifikacija"
},
"button": {
"apply": "Uporabi",
@@ -80,7 +202,7 @@
"back": "Nazaj",
"pictureInPicture": "Slika v Sliki",
"history": "Zgodovina",
- "disabled": "Izklopljeno",
+ "disabled": "Onemogočeno",
"copy": "Kopiraj",
"exitFullscreen": "Izhod iz Celozaslonskega načina",
"enabled": "Omogočen",
@@ -88,7 +210,26 @@
"save": "Shrani",
"saving": "Shranjevanje …",
"cancel": "Prekliči",
- "fullscreen": "Celozaslonski način"
+ "fullscreen": "Celozaslonski način",
+ "twoWayTalk": "Dvosmerni Pogovor",
+ "cameraAudio": "Zvok Kamere",
+ "on": "Vključen",
+ "off": "Izključen",
+ "edit": "Uredi",
+ "copyCoordinates": "Kopiraj koordinate",
+ "delete": "Izbriši",
+ "yes": "Da",
+ "no": "Ne",
+ "download": "Prenesi",
+ "info": "Info",
+ "suspended": "Začasno ustavljeno",
+ "unsuspended": "Obnovi",
+ "play": "Predvajaj",
+ "unselect": "Odznači",
+ "export": "Izvoz",
+ "deleteNow": "Izbriši Zdaj",
+ "next": "Naprej",
+ "continue": "Nadaljuj"
},
"unit": {
"speed": {
@@ -98,14 +239,75 @@
"length": {
"feet": "čevelj",
"meters": "metri"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/uro",
+ "mbph": "MB/uro",
+ "gbph": "GB/uro"
}
},
"label": {
- "back": "Pojdi nazaj"
+ "back": "Pojdi nazaj",
+ "hide": "Skrij {{item}}",
+ "show": "Prikaži {{item}}",
+ "ID": "ID",
+ "none": "Brez",
+ "all": "Vse",
+ "other": "Drugo"
},
"pagination": {
"next": {
- "label": "Pojdi na naslednjo stran"
+ "label": "Pojdi na naslednjo stran",
+ "title": "Naprej"
+ },
+ "label": "paginacija",
+ "previous": {
+ "title": "Prejšnji",
+ "label": "Pojdi na prejšnjo stran"
+ },
+ "more": "Več strani"
+ },
+ "selectItem": "Izberi {{item}}",
+ "toast": {
+ "copyUrlToClipboard": "Povezava kopirana v odložišče.",
+ "save": {
+ "title": "Shrani",
+ "error": {
+ "title": "Napaka pri shranjevanju sprememb: {{errorMessage}}",
+ "noMessage": "Napaka pri shranjevanju sprememb konfiguracije"
+ }
}
+ },
+ "role": {
+ "title": "Vloga",
+ "admin": "Administrator",
+ "viewer": "Gledalec",
+ "desc": "Administratorji imajo poln dostop do vseh funkcij Frigate uporabniškega vmesnika. Gledalci so omejeni na gledanje kamer, zgodovine posnetkov in pregledovanje dogodkov."
+ },
+ "accessDenied": {
+ "documentTitle": "Dostop zavrnjen - Frigate",
+ "title": "Dostop Zavrnjen",
+ "desc": "Nimate pravic za ogled te strani."
+ },
+ "notFound": {
+ "documentTitle": "Ni Najdeno - Frigate",
+ "title": "404",
+ "desc": "Stran ni najdena"
+ },
+ "readTheDocumentation": "Preberite dokumentacijo",
+ "list": {
+ "two": "{{0}} in {{1}}",
+ "many": "{{items}}, in {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Izbirno",
+ "internalID": "Interni ID, ki ga Frigate uporablja v konfiguraciji in podatkovni bazi"
+ },
+ "information": {
+ "pixels": "{{area}}px"
}
}
diff --git a/web/public/locales/sl/components/auth.json b/web/public/locales/sl/components/auth.json
index 547381ca1..383b8dde4 100644
--- a/web/public/locales/sl/components/auth.json
+++ b/web/public/locales/sl/components/auth.json
@@ -10,6 +10,7 @@
"loginFailed": "Prijava ni uspela",
"unknownError": "Neznana napaka. Preverite dnevnike.",
"webUnknownError": "Neznana napaka. Preverite dnevnike konzole."
- }
+ },
+ "firstTimeLogin": "Se poskušate prijaviti prvič? Prijavni podatki so zapisani v Frigate dnevniku."
}
}
diff --git a/web/public/locales/sl/components/camera.json b/web/public/locales/sl/components/camera.json
index 9ee8f4046..dc2e593af 100644
--- a/web/public/locales/sl/components/camera.json
+++ b/web/public/locales/sl/components/camera.json
@@ -50,7 +50,8 @@
},
"placeholder": "Izberite tok",
"stream": "Tok"
- }
+ },
+ "birdseye": "Ptičji pogled"
},
"name": {
"label": "Ime",
@@ -72,9 +73,9 @@
"debug": {
"options": {
"label": "Nastavitve",
- "title": "Lastnosti",
- "showOptions": "Prikaži lastnosti",
- "hideOptions": "Skrij lastnosti"
+ "title": "Možnosti",
+ "showOptions": "Prikaži Možnosti",
+ "hideOptions": "Skrij Možnosti"
},
"boundingBox": "Omejitve okvirja",
"timestamp": "Časovni žig",
diff --git a/web/public/locales/sl/components/dialog.json b/web/public/locales/sl/components/dialog.json
index e63f7c34b..02295afee 100644
--- a/web/public/locales/sl/components/dialog.json
+++ b/web/public/locales/sl/components/dialog.json
@@ -12,11 +12,18 @@
"plus": {
"review": {
"question": {
- "ask_full": "Ali je ta objekt {{untranslatedLabel}} ({{translatedLabel}})?"
+ "ask_full": "Ali je ta objekt {{untranslatedLabel}} ({{translatedLabel}})?",
+ "label": "Potrdi to oznako za Frigate Plus",
+ "ask_a": "Ali je ta objekt {{label}}?",
+ "ask_an": "Ali je ta objekt {{label}}?"
},
"state": {
"submitted": "Oddano"
}
+ },
+ "submitToPlus": {
+ "label": "Pošlji v Frigate+",
+ "desc": "Predmeti na lokacijah, ki se jim želite izogniti, niso lažni alarmi. Če jih označite kot lažne alarme, boste zmedli model."
}
},
"video": {
@@ -25,10 +32,94 @@
},
"export": {
"time": {
- "lastHour_one": "Zadnja ura",
+ "lastHour_one": "Zadnja {{count}} ura",
"lastHour_two": "Zadnji {{count}} uri",
"lastHour_few": "Zadnje {{count}} ure",
- "lastHour_other": "Zadnjih {{count}} ur"
+ "lastHour_other": "Zadnjih {{count}} ur",
+ "fromTimeline": "Izberi s Časovnice",
+ "custom": "Po meri",
+ "start": {
+ "title": "Začetni čas",
+ "label": "Izberi Začetni Čas"
+ },
+ "end": {
+ "title": "Končni Čas",
+ "label": "Izberi Končni Čas"
+ }
+ },
+ "name": {
+ "placeholder": "Poimenujte Izvoz"
+ },
+ "select": "Izberi",
+ "export": "Izvoz",
+ "selectOrExport": "Izberi ali Izvozi",
+ "toast": {
+ "success": "Izvoz se je uspešno začel. Datoteko si oglejte v izvozih.",
+ "error": {
+ "failed": "Npaka pri začetku izvoza: {{error}}",
+ "endTimeMustAfterStartTime": "Končni čas mora biti po začetnem čase",
+ "noVaildTimeSelected": "Ni izbranega veljavnega časovnega obdobja"
+ },
+ "view": "Pregled"
+ },
+ "fromTimeline": {
+ "saveExport": "Shrani Izvoz",
+ "previewExport": "Predogled Izvoza"
}
+ },
+ "streaming": {
+ "label": "Pretakanje",
+ "restreaming": {
+ "disabled": "Ponovno pretakanje za to kamero ni omogočeno.",
+ "desc": {
+ "title": "Za dodatne možnosti ogleda v živo in zvoka za to kamero nastavite go2rtc.",
+ "readTheDocumentation": "Preberi dokumentacijo"
+ }
+ },
+ "showStats": {
+ "label": "Prikaži statistiko pretoka",
+ "desc": "Omogočite to možnost, če želite prikazati statistiko pretoka videa kamere."
+ },
+ "debugView": "Pogled za Odpravljanje Napak"
+ },
+ "search": {
+ "saveSearch": {
+ "label": "Shrani iskanje",
+ "desc": "Vnesite ime za to shranjeno iskanje.",
+ "placeholder": "Vnesite ime za iskanje",
+ "overwrite": "{{searchName}} že obstaja. Shranjevanje bo prepisalo obstoječo vrednost.",
+ "success": "Iskanje ({{searchName}}) je bilo shranjeno.",
+ "button": {
+ "save": {
+ "label": "Shrani to iskanje"
+ }
+ }
+ }
+ },
+ "recording": {
+ "confirmDelete": {
+ "title": "Potrdi Brisanje",
+ "desc": {
+ "selected": "Ali ste prepričani, da želite izbrisati vse posnete videoposnetke, povezane s tem elementom pregleda?
Držite tipko Shift, da se v prihodnje izognete temu pogovornemu oknu."
+ },
+ "toast": {
+ "success": "Videoposnetek, povezan z izbranimi elementi pregleda, je bil uspešno izbrisan.",
+ "error": "Brisanje ni uspelo: {{error}}"
+ }
+ },
+ "button": {
+ "export": "Izvoz",
+ "markAsReviewed": "Označi kot pregledano",
+ "deleteNow": "Izbriši Zdaj",
+ "markAsUnreviewed": "Označi kot nepregledano"
+ }
+ },
+ "imagePicker": {
+ "selectImage": "Izberite sličico sledenega predmeta",
+ "search": {
+ "placeholder": "Iskanje po oznaki ali podoznaki..."
+ },
+ "noImages": "Za to kamero ni bilo najdenih sličic",
+ "unknownLabel": "Shranjena slika prožilca"
}
}
diff --git a/web/public/locales/sl/components/filter.json b/web/public/locales/sl/components/filter.json
index b202e1554..93be539b1 100644
--- a/web/public/locales/sl/components/filter.json
+++ b/web/public/locales/sl/components/filter.json
@@ -20,7 +20,28 @@
"explore": {
"settings": {
"defaultView": {
- "summary": "Povzetek"
+ "summary": "Povzetek",
+ "title": "Privzeti Pogled",
+ "desc": "Če filtri niso izbrani, prikaži povzetek najnovejših sledenih objektov na oznako ali prikaži nefiltrirano mrežo.",
+ "unfilteredGrid": "Nefiltrirana Mreža"
+ },
+ "title": "Nastavitve",
+ "gridColumns": {
+ "title": "Mrežni Stolpci",
+ "desc": "Izberite število stolpcev v pogledu mreže."
+ },
+ "searchSource": {
+ "label": "Iskanje Vira",
+ "desc": "Izberite, ali želite iskati po sličicah ali opisih sledenih objektov.",
+ "options": {
+ "thumbnailImage": "Sličica",
+ "description": "Opis"
+ }
+ }
+ },
+ "date": {
+ "selectDateBy": {
+ "label": "Izberite datum za filtriranje"
}
}
},
@@ -30,7 +51,13 @@
},
"sort": {
"relevance": "Ustreznost",
- "dateAsc": "Datum (naraščajoče)"
+ "dateAsc": "Datum (naraščajoče)",
+ "label": "Sortiraj",
+ "dateDesc": "Datum (Padajoče)",
+ "scoreAsc": "Ocena Predmeta (Naraščajoče)",
+ "scoreDesc": "Ocena predmeta (Padajoče)",
+ "speedAsc": "Ocenjena Hitrost (Naraščajoče)",
+ "speedDesc": "Ocenjena Hitrost (Padajoče)"
},
"zones": {
"label": "Cone",
@@ -45,7 +72,13 @@
},
"logSettings": {
"disableLogStreaming": "Izklopite zapisovanje dnevnika",
- "allLogs": "Vsi dnevniki"
+ "allLogs": "Vsi dnevniki",
+ "label": "Level Filtra Dnevnika",
+ "filterBySeverity": "Filtriraj dnevnike po resnosti",
+ "loading": {
+ "title": "Nalaganje",
+ "desc": "Ko se podokno dnevnika pomakne čisto na dno, se novi dnevniki samodejno prikažejo, ko so dodani."
+ }
},
"trackedObjectDelete": {
"title": "Potrdite brisanje",
@@ -57,5 +90,51 @@
},
"zoneMask": {
"filterBy": "Filtrirajte po maski območja"
+ },
+ "classes": {
+ "label": "Razredi",
+ "all": {
+ "title": "Vsi Razredi"
+ },
+ "count_one": "{{count}} Razred",
+ "count_other": "{{count}} Razredov"
+ },
+ "score": "Ocena",
+ "estimatedSpeed": "Ocenjena Hitrost ({{unit}})",
+ "features": {
+ "label": "Lastnosti",
+ "hasSnapshot": "Ima sliko",
+ "hasVideoClip": "Ima posnetek",
+ "submittedToFrigatePlus": {
+ "label": "Poslano na Frigate+",
+ "tips": "Najprej morate filtrirati po sledenih objektih, ki imajo sliko.
Slednih objektov brez slike ni mogoče poslati v Frigate+."
+ }
+ },
+ "cameras": {
+ "label": "Filtri Kamere",
+ "all": {
+ "title": "Vse Kamere",
+ "short": "Kamere"
+ }
+ },
+ "review": {
+ "showReviewed": "Prikaži Pregledano"
+ },
+ "motion": {
+ "showMotionOnly": "Prikaži Samo Gibanje"
+ },
+ "recognizedLicensePlates": {
+ "title": "Prepoznane Registrske Tablice",
+ "loadFailed": "Prepoznanih registrskih tablic ni bilo mogoče naložiti.",
+ "loading": "Nalaganje prepoznanih registrskih tablic…",
+ "placeholder": "Iskanje registrskih tablic…",
+ "noLicensePlatesFound": "Nobena registrska tablica ni bila najdena.",
+ "selectPlatesFromList": "Na seznamu izberite eno ali več registrskih tablic.",
+ "selectAll": "Izberi vse",
+ "clearAll": "Počisti vse"
+ },
+ "attributes": {
+ "label": "Atributi klasifikacije",
+ "all": "Vsi atributi"
}
}
diff --git a/web/public/locales/sl/views/classificationModel.json b/web/public/locales/sl/views/classificationModel.json
new file mode 100644
index 000000000..513084549
--- /dev/null
+++ b/web/public/locales/sl/views/classificationModel.json
@@ -0,0 +1,75 @@
+{
+ "description": {
+ "invalidName": "Neveljavno ime. Ime lahko vsebuje črke, števila, presledke, narekovaje, podčrtaje in pomišljaje."
+ },
+ "categories": "Razredi",
+ "createCategory": {
+ "new": "Naredi nov razred"
+ },
+ "button": {
+ "renameCategory": "Preimenuj razred",
+ "deleteCategory": "Zbriši razred",
+ "deleteImages": "Zbriši slike",
+ "trainModel": "Treniraj model",
+ "deleteClassificationAttempts": "Izbriši klasifikacijske slike",
+ "addClassification": "Dodaj klasifikacijo",
+ "deleteModels": "Izbriši model",
+ "editModel": "Uredi model"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Izbrisan razred",
+ "deletedImage": "Zbrisane slike",
+ "trainedModel": "Uspešno treniranje modela.",
+ "trainingModel": "Uspešen začetek treniranje modela.",
+ "deletedModel_one": "Uspešno izbrisan {{count}} model",
+ "deletedModel_two": "Uspešno izbrisana {{count}} modela",
+ "deletedModel_few": "Uspešno izbrisani {{count}} modeli",
+ "deletedModel_other": "Uspešno izbrisanih {{count}} modelov",
+ "categorizedImage": "Uspešna klasifikacija slike",
+ "updatedModel": "Uspešno posodobljene podrobnosti modela",
+ "renamedCategory": "Uspešno preimenovan razred v {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Neuspešno brisanje: {{errorMessage}}",
+ "deleteCategoryFailed": "Neuspešno brisanje razreda: {{errorMessage}}",
+ "trainingFailed": "Neuspešen začetek treniranje modela: {{errorMessage}}",
+ "deleteModelFailed": "Napaka pri brisanju modela: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Zbriši razred"
+ },
+ "deleteTrainImages": {
+ "title": "Zbriši slike za treniranje",
+ "desc": "Ali ste prepričani, da želite izbrisati {{count}} slik? Tega dejanja ni mogoče razveljaviti."
+ },
+ "renameCategory": {
+ "title": "Preimenuj razred",
+ "desc": "Vnesite novo ime za {{name}}. Model bo treba znova naučiti, da bo sprememba imena začela veljati."
+ },
+ "train": {
+ "title": "Nedavne razvrstitve",
+ "aria": "Izberi nedavne razvrstitve",
+ "titleShort": "Nedavno"
+ },
+ "categorizeImageAs": "Razvrsti sliko kot:",
+ "categorizeImage": "Razvrsti sliko",
+ "noModels": {
+ "object": {
+ "title": "Ni modelov za razvrščanje objektov"
+ }
+ },
+ "documentTitle": "Klasifikacijski modeli - fregate",
+ "details": {
+ "scoreInfo": "Razultat predstavlja povprečno stopnjo sigurnosti čez vsa zaznavynja objekta.",
+ "none": "Nobeno",
+ "unknown": "Neznano"
+ },
+ "tooltip": {
+ "trainingInProgress": "Model se trenutno trenira",
+ "noNewImages": "Novih slik za treniranje ni na voljo. Označite več slik v bazi.",
+ "noChanges": "Ni sprememb v bazi od zadnjega treniranja.",
+ "modelNotReady": "Model ni pripravljen na treniranje"
+ }
+}
diff --git a/web/public/locales/sl/views/configEditor.json b/web/public/locales/sl/views/configEditor.json
index b8f76525d..5c69cc1b4 100644
--- a/web/public/locales/sl/views/configEditor.json
+++ b/web/public/locales/sl/views/configEditor.json
@@ -12,5 +12,7 @@
"savingError": "Napaka pri shranjevanju konfiguracije"
}
},
- "confirm": "Izhod brez shranjevanja?"
+ "confirm": "Izhod brez shranjevanja?",
+ "safeConfigEditor": "Urejevalnik konfiguracij (Varni Način)",
+ "safeModeDescription": "Frigate je v varnem načinu zaradi napake pri preverjanju konfiguracije."
}
diff --git a/web/public/locales/sl/views/events.json b/web/public/locales/sl/views/events.json
index a0570b959..e0e07e3c0 100644
--- a/web/public/locales/sl/views/events.json
+++ b/web/public/locales/sl/views/events.json
@@ -9,7 +9,11 @@
"empty": {
"motion": "Ni najdenih podatkov o gibanju",
"alert": "Ni opozoril za pregled",
- "detection": "Ni zaznanih elementov za pregled"
+ "detection": "Ni zaznanih elementov za pregled",
+ "recordingsDisabled": {
+ "title": "Snemanje mora biti omogočeno",
+ "description": "Elemente pregleda je mogoče ustvariti le za kamero, če so za to kamero omogočeni posnetki."
+ }
},
"recordings": {
"documentTitle": "Posnetki - Frigate"
@@ -34,5 +38,28 @@
"button": "Novi elementi za pregled"
},
"selected_one": "{{count}} izbranih",
- "selected_other": "{{count}} izbranih"
+ "selected_other": "{{count}} izbranih",
+ "zoomIn": "Povečaj",
+ "zoomOut": "Pomanjšaj",
+ "detail": {
+ "label": "Podrobnosti",
+ "noDataFound": "Ni podrobnosti za preverbo",
+ "aria": "Preklopi pregled podrobnosti",
+ "trackedObject_one": "objektov: {{count}}",
+ "trackedObject_other": "objektov: {{count}}",
+ "noObjectDetailData": "Ni podrobnosti za izbran objekt.",
+ "settings": "Nastavitve pregleda podrobnosti",
+ "alwaysExpandActive": {
+ "title": "Vedno razširi aktivne",
+ "desc": "Vedno razširi podrobnosti objektov aktivnega elementa pregleda, če so na voljo."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Točka za sledenje",
+ "clickToSeek": "Pritisnite, da se premaknete na izbran čas"
+ },
+ "select_all": "Vse",
+ "normalActivity": "Normalno",
+ "needsReview": "Potrebuje pregled",
+ "securityConcern": "Varnostno tveganje"
}
diff --git a/web/public/locales/sl/views/explore.json b/web/public/locales/sl/views/explore.json
index 97e7ca664..6cb7011ad 100644
--- a/web/public/locales/sl/views/explore.json
+++ b/web/public/locales/sl/views/explore.json
@@ -3,15 +3,28 @@
"title": "Funkcija razišči ni na voljo",
"downloadingModels": {
"setup": {
- "visionModel": "Model vida"
+ "visionModel": "Model vida",
+ "visionModelFeatureExtractor": "Pridobivanje lastnosti modela vida",
+ "textModel": "Besedilni model",
+ "textTokenizer": "Tokenizator besedila"
},
- "context": "Frigate prenaša potrebne modele vdelave za podporo funkcije semantičnega iskanja. To lahko traja nekaj minut, odvisno od hitrosti vaše omrežne povezave."
+ "context": "Frigate prenaša potrebne modele vdelave za podporo funkcije semantičnega iskanja. To lahko traja nekaj minut, odvisno od hitrosti vaše omrežne povezave.",
+ "tips": {
+ "context": "Morda boste želeli ponovno indeksirati vdelave (embeddings) svojih sledenih objektov, ko bodo modeli preneseni.",
+ "documentation": "Preberi dokumentacijo"
+ },
+ "error": "Prišlo je do napake. Preverite dnevnike Frigate."
},
"embeddingsReindexing": {
"step": {
"descriptionsEmbedded": "Vdelani opisi: ",
- "trackedObjectsProcessed": "Obdelani sledeni predmeti: "
- }
+ "trackedObjectsProcessed": "Obdelani sledeni predmeti: ",
+ "thumbnailsEmbedded": "Vdelane sličice: "
+ },
+ "context": "Funkcija Explore se lahko uporablja, ko je ponovno indeksiranje vgraditev(embeddings) sledenih objektov končano.",
+ "startingUp": "Zagon…",
+ "estimatedTime": "Ocenjeni preostali čas:",
+ "finishingShortly": "Kmalu končano"
}
},
"documentTitle": "Razišči - Frigate",
@@ -29,12 +42,61 @@
"estimatedSpeed": "Ocenjena hitrost",
"description": {
"placeholder": "Opis sledenega predmeta",
- "label": "Opis"
+ "label": "Opis",
+ "aiTips": "Frigate od vašega ponudnika generativne UI ne bo zahteval opisa, dokler se življenjski cikel sledenega objekta ne konča."
},
"recognizedLicensePlate": "Prepoznana registrska tablica",
"objects": "Predmeti",
"zones": "Območja",
- "timestamp": "Časovni žig"
+ "timestamp": "Časovni žig",
+ "item": {
+ "button": {
+ "share": "Deli ta element mnenja",
+ "viewInExplore": "Poglej v Razišči Pogledu"
+ },
+ "tips": {
+ "hasMissingObjects": "Prilagodite konfiguracijo, če želite, da Frigate shranjuje sledene objekte za naslednje oznake: {{objects}}"
+ },
+ "toast": {
+ "success": {
+ "regenerate": "Od ponudnika {{provider}} je bil zahtevan nov opis. Glede na hitrost vašega ponudnika lahko regeneracija novega opisa traja nekaj časa.",
+ "updatedSublabel": "Podoznaka je bila uspešno posodobljena.",
+ "updatedLPR": "Registrska tablica je bila uspešno posodobljena.",
+ "audioTranscription": "Zahteva za zvočni prepis je bila uspešno izvedena."
+ },
+ "error": {
+ "regenerate": "Klic ponudniku {{provider}} za nov opis ni uspel: {{errorMessage}}",
+ "updatedSublabelFailed": "Posodobitev podoznake ni uspela: {{errorMessage}}",
+ "updatedLPRFailed": "Posodobitev registrske tablice ni uspela: {{errorMessage}}",
+ "audioTranscription": "Zahteva za prepis zvoka ni uspela: {{errorMessage}}"
+ }
+ },
+ "title": "Preglej Podrobnosti Elementa",
+ "desc": "Preglej podrobnosti elementa"
+ },
+ "label": "Oznaka",
+ "editSubLabel": {
+ "title": "Uredi podoznako",
+ "desc": "Vnesite novo podoznako za {{label}}",
+ "descNoLabel": "Vnesite novo podoznako za ta sledeni objekt"
+ },
+ "editLPR": {
+ "title": "Uredi registrsko tablico",
+ "desc": "Vnesite novo vrednost registrske tablice za {{label}}",
+ "descNoLabel": "Vnesite novo vrednost registrske tablice za ta sledeni objekt"
+ },
+ "snapshotScore": {
+ "label": "Ocena Slike"
+ },
+ "topScore": {
+ "label": "Najboljša Ocena",
+ "info": "Najboljša ocena je najvišji mediani rezultat za sledeni objekt, zato se lahko razlikuje od rezultata, prikazanega na sličici rezultata iskanja."
+ },
+ "expandRegenerationMenu": "Razširi meni regeneracije",
+ "tips": {
+ "descriptionSaved": "Opis uspešno shranjen",
+ "saveDescriptionFailed": "Opisa ni bilo mogoče posodobiti: {{errorMessage}}"
+ }
},
"itemMenu": {
"findSimilar": {
@@ -63,11 +125,92 @@
"downloadSnapshot": {
"label": "Prenesi posnetek",
"aria": "Prenesi posnetek"
+ },
+ "addTrigger": {
+ "label": "Dodaj sprožilec",
+ "aria": "Dodaj sprožilec za ta sledeni objekt"
+ },
+ "audioTranscription": {
+ "label": "Prepis",
+ "aria": "Zahtevajte prepis zvoka"
}
},
"dialog": {
"confirmDelete": {
"title": "Potrdi brisanje"
}
+ },
+ "trackedObjectDetails": "Podrobnosti Sledenega Objekta",
+ "type": {
+ "details": "podrobnosti",
+ "snapshot": "posnetek",
+ "video": "video",
+ "object_lifecycle": "življenjski cikel objekta",
+ "thumbnail": "sličica",
+ "tracking_details": "podrobnosti sledenja"
+ },
+ "objectLifecycle": {
+ "title": "Življenjski Cikel Objekta",
+ "noImageFound": "Za ta čas ni bila najdena nobena slika.",
+ "createObjectMask": "Ustvarite Masko Objekta",
+ "adjustAnnotationSettings": "Prilagodi nastavitve opomb",
+ "scrollViewTips": "Pomaknite se, da si ogledate pomembne trenutke življenjskega cikla tega predmeta.",
+ "count": "{{first}} od {{second}}",
+ "trackedPoint": "Sledena točka",
+ "lifecycleItemDesc": {
+ "visible": "{{label}} zaznan",
+ "entered_zone": "{{label}} je vstopil/a v {{zones}}",
+ "active": "{{label}} je postal aktiven",
+ "stationary": "{{label}} je postal nepremičen",
+ "attribute": {
+ "faceOrLicense_plate": "{{attribute}} je bil zaznan za {{label}}",
+ "other": "{{label}} zaznan kot {{attribute}}"
+ },
+ "gone": "{{label}} levo",
+ "heard": "{{label}} slišano",
+ "external": "{{label}} zaznan",
+ "header": {
+ "zones": "Cone",
+ "ratio": "Razmerje",
+ "area": "Območje"
+ }
+ },
+ "annotationSettings": {
+ "title": "Nastavitve Anotacij",
+ "showAllZones": {
+ "title": "Prikaži Vse Cone",
+ "desc": "Vedno prikaži območja na okvirjih, kjer so predmeti vstopili v območje."
+ },
+ "offset": {
+ "label": "Anotacijski Odmik",
+ "documentation": "Preberi dokumentacijo ",
+ "millisecondsToOffset": "Odmik zaznanih anotacij v milisekundah. Privzeto: 0",
+ "tips": "NASVET: Predstavljajte si posnetek dogodka, v katerem oseba hodi od leve proti desni. Če je okvir dogodka na časovnici preveč levo od osebe, je treba vrednost zmanjšati. Podobno je treba vrednost povečati, če oseba hodi od leve proti desni in je okvir preveč pred njo.",
+ "toast": {
+ "success": "Odmik anotacij za {{camera}} je bil shranjen v konfiguracijsko datoteko. Znova zaženite Frigate, da uveljavite spremembe."
+ }
+ }
+ },
+ "carousel": {
+ "previous": "Prejšnji diapozitiv",
+ "next": "Naslednji diapozitiv"
+ },
+ "autoTrackingTips": "Položaji okvirjev bodo za kamere s samodejnim sledenjem netočni."
+ },
+ "noTrackedObjects": "Ni Najdenih Sledenih Objektov",
+ "fetchingTrackedObjectsFailed": "Napaka pri pridobivanju sledenih objektov: {{errorMessage}}",
+ "searchResult": {
+ "tooltip": "Ujemanje {{type}} pri {{confidence}}%",
+ "deleteTrackedObject": {
+ "toast": {
+ "success": "Sledeni objekt je bil uspešno izbrisan.",
+ "error": "Brisanje sledenega predmeta ni uspelo: {{errorMessage}}"
+ }
+ }
+ },
+ "trackingDetails": {
+ "title": "Podrobnosti sledenja",
+ "noImageFound": "Ni najdenih slik za izbrani datum in čas.",
+ "createObjectMask": "Ustvari masko predmeta"
}
}
diff --git a/web/public/locales/sl/views/exports.json b/web/public/locales/sl/views/exports.json
index 59ca52181..1afd16697 100644
--- a/web/public/locales/sl/views/exports.json
+++ b/web/public/locales/sl/views/exports.json
@@ -13,5 +13,11 @@
"error": {
"renameExportFailed": "Napaka pri preimenovanju izvoza: {{errorMessage}}"
}
+ },
+ "tooltip": {
+ "shareExport": "Deli izvoz",
+ "editName": "Uredi ime",
+ "deleteExport": "Izbriši izvoz",
+ "downloadVideo": "Prenesi videoposnetek"
}
}
diff --git a/web/public/locales/sl/views/faceLibrary.json b/web/public/locales/sl/views/faceLibrary.json
index d59acc47e..9e30a565b 100644
--- a/web/public/locales/sl/views/faceLibrary.json
+++ b/web/public/locales/sl/views/faceLibrary.json
@@ -1,22 +1,28 @@
{
"description": {
- "addFace": "Sprehodite se skozi dodajanje nove zbirke v knjižnico obrazov.",
+ "addFace": "Dodaj novo zbirko v knjižnico obrazov tako, da naložiš svojo prvo sliko.",
"placeholder": "Vnesite ime za to zbirko",
"invalidName": "Neveljavno ime. Ime lahko vsebuje črke, števila, presledke, narekovaje, podčrtaje in pomišljaje."
},
"details": {
"person": "Oseba",
- "unknown": "Nenznano",
- "timestamp": "Časovni žig"
+ "unknown": "Neznano",
+ "timestamp": "Časovni žig",
+ "subLabelScore": "Ocena Podoznake",
+ "scoreInfo": "Rezultat podoznake je utežena ocena vseh stopenj gotovosti prepoznanih obrazov, zato se lahko razlikuje od ocene, prikazane na posnetku.",
+ "face": "Podrobnosti Obraza",
+ "faceDesc": "Podrobnosti sledenega objekta, ki je ustvaril ta obraz"
},
"uploadFaceImage": {
- "title": "Naloži nov obraz"
+ "title": "Naloži nov obraz",
+ "desc": "Naloži sliko za iskanje obrazov in vključitev v {{pageToggle}}"
},
"deleteFaceAttempts": {
"desc_one": "Ali ste prepričani, da želite izbrisati {{count}} obraz? Tega dejanja ni mogoče razveljaviti.",
"desc_two": "Ali ste prepričani, da želite izbrisati {{count}} obraza? Tega dejanja ni mogoče razveljaviti.",
"desc_few": "Ali ste prepričani, da želite izbrisati {{count}} obraze? Tega dejanja ni mogoče razveljaviti.",
- "desc_other": "Ali ste prepričani, da želite izbrisati {{count}} obrazov? Tega dejanja ni mogoče razveljaviti."
+ "desc_other": "Ali ste prepričani, da želite izbrisati {{count}} obrazov? Tega dejanja ni mogoče razveljaviti.",
+ "title": "Izbriši Obraze"
},
"toast": {
"success": {
@@ -27,8 +33,74 @@
"deletedName_one": "{{count}} je bil uspešno izbrisan.",
"deletedName_two": "{{count}} obraza sta bila uspešno izbrisana.",
"deletedName_few": "{{count}} obrazi so bili uspešno izbrisani.",
- "deletedName_other": "{{count}} obrazov je bilo uspešno izbrisanih."
+ "deletedName_other": "{{count}} obrazov je bilo uspešno izbrisanih.",
+ "uploadedImage": "Slika je bila uspešno naložena.",
+ "addFaceLibrary": "Oseba {{name}} je bila uspešno dodana v Knjižnico Obrazov!",
+ "renamedFace": "Obraz uspešno preimenovan v {{name}}",
+ "trainedFace": "Uspešno treniran obraz.",
+ "updatedFaceScore": "Ocena obraza je bila uspešno posodobljena {{name}} ({{score}})."
+ },
+ "error": {
+ "uploadingImageFailed": "Nalaganje slike ni uspelo: {{errorMessage}}",
+ "addFaceLibraryFailed": "Neuspešno nastavljanje imena obraza: {{errorMessage}}",
+ "deleteFaceFailed": "Brisanje ni uspelo: {{errorMessage}}",
+ "deleteNameFailed": "Brisanje imena ni uspelo: {{errorMessage}}",
+ "renameFaceFailed": "Preimenovanje obraza ni uspelo: {{errorMessage}}",
+ "trainFailed": "Treniranje ni uspelo: {{errorMessage}}",
+ "updateFaceScoreFailed": "Posodobitev ocene obraza ni uspela: {{errorMessage}}"
}
},
- "documentTitle": "Knjižnica obrazov - Frigate"
+ "documentTitle": "Knjižnica obrazov - Frigate",
+ "collections": "Zbirke",
+ "createFaceLibrary": {
+ "title": "Ustvari Zbirko",
+ "desc": "Ustvari novo zbirko",
+ "new": "Ustvari Nov Obraz",
+ "nextSteps": "Za vzpoztavitev trdnih osnov: V zavihku Nedavne prepoznave izberi in uporabi slike za učenje vsake zaznane osebe. Za najboljše rezultate se osredotoči na slike, kjer je obraz obrnjen naravnost; izogibaj se slikam, na katerih so obrazi posneti pod kotom. "
+ },
+ "steps": {
+ "faceName": "Vnesi Ime Obraza",
+ "uploadFace": "Naloži Sliko Obraza",
+ "nextSteps": "Naslednji koraki",
+ "description": {
+ "uploadFace": "Naložite sliko osebe {{name}}, ki prikazuje obraz (slikan naravnost in ne iz kota). Slike ni treba obrezati samo na obraz."
+ }
+ },
+ "train": {
+ "title": "Nedavne prepoznave",
+ "aria": "Izberite nedavne prepoznave",
+ "empty": "Ni nedavnih poskusov prepoznavanja obrazov",
+ "titleShort": "Nedavno"
+ },
+ "selectItem": "Izberi {{item}}",
+ "selectFace": "Izberi Obraz",
+ "deleteFaceLibrary": {
+ "title": "Izbriši Ime",
+ "desc": "Ali ste prepričani, da želite izbrisati zbirko {{name}}? S tem boste trajno izbrisali vse povezane obraze."
+ },
+ "renameFace": {
+ "title": "Preimenuj Obraz",
+ "desc": "Vnesi novo ime za {{name}}"
+ },
+ "button": {
+ "deleteFaceAttempts": "Izbriši Obraze",
+ "addFace": "Dodaj Obraz",
+ "renameFace": "Preimenuj Obraz",
+ "deleteFace": "Izbriši Obraz",
+ "uploadImage": "Naloži Sliko",
+ "reprocessFace": "Ponovna Obdelava Obraza"
+ },
+ "imageEntry": {
+ "validation": {
+ "selectImage": "Izberite slikovno datoteko."
+ },
+ "dropActive": "Sliko spustite tukaj…",
+ "dropInstructions": "Povlecite in spustite ali prilepite sliko sem ali kliknite za izbiro",
+ "maxSize": "Največja velikost: {{size}}MB"
+ },
+ "nofaces": "Noben obraz ni na voljo",
+ "pixels": "{{area}}px",
+ "readTheDocs": "Preberi dokumentacijo",
+ "trainFaceAs": "Treniraj obraz kot:",
+ "trainFace": "Treniraj Obraz"
}
diff --git a/web/public/locales/sl/views/live.json b/web/public/locales/sl/views/live.json
index 212137ba7..5b5261828 100644
--- a/web/public/locales/sl/views/live.json
+++ b/web/public/locales/sl/views/live.json
@@ -9,14 +9,163 @@
"ptz": {
"move": {
"clickMove": {
- "disable": "Onemogoči funkcijo klikni in premakni"
+ "disable": "Onemogoči funkcijo klikni in premakni",
+ "label": "Kliknite v okvir, da postavite kamero na sredino",
+ "enable": "Omogoči premik s klikom"
},
"left": {
"label": "Premakni PTZ kamero v levo"
},
"up": {
"label": "Premakni PTZ kamero gor"
+ },
+ "down": {
+ "label": "Premakni PTZ kamero navzdol"
+ },
+ "right": {
+ "label": "Premakni PTZ kamero desno"
}
+ },
+ "zoom": {
+ "in": {
+ "label": "Povečaj PTZ kamero"
+ },
+ "out": {
+ "label": "Pomanjšaj PTZ kamero"
+ }
+ },
+ "focus": {
+ "in": {
+ "label": "Izostri PTZ kamero"
+ },
+ "out": {
+ "label": "Razostri PTZ kamero"
+ }
+ },
+ "frame": {
+ "center": {
+ "label": "Kliknite v okvir, da postavite PTZ kamero na sredino"
+ }
+ },
+ "presets": "Prednastavitve PTZ kamere"
+ },
+ "cameraAudio": {
+ "enable": "Omogoči Zvok Kamere",
+ "disable": "Onemogoči Zvok Kamere"
+ },
+ "camera": {
+ "enable": "Omogoči Kamero",
+ "disable": "Onemogoči Kamero"
+ },
+ "muteCameras": {
+ "enable": "Utišaj vse kamere",
+ "disable": "Vklopi Zvok Vsem Kameram"
+ },
+ "detect": {
+ "enable": "Omogoči Detekcijo",
+ "disable": "Onemogoči Detekcijo"
+ },
+ "recording": {
+ "enable": "Omogoči Snemanje",
+ "disable": "Onemogoči Snemanje"
+ },
+ "snapshots": {
+ "enable": "Omogoči Slike",
+ "disable": "Onemogoči Slike"
+ },
+ "audioDetect": {
+ "enable": "Omogoči Zvočno Detekcijo",
+ "disable": "Onemogoči Zvočno Detekcijo"
+ },
+ "transcription": {
+ "enable": "Omogoči Prepisovanje Zvoka v Živo",
+ "disable": "Onemogoči Prepisovanje Zvoka v Živo"
+ },
+ "autotracking": {
+ "enable": "Omogoči Samodejno Sledenje",
+ "disable": "Onemogoči Samodejno Sledenje"
+ },
+ "streamStats": {
+ "enable": "Prikaži Statistiko Pretočnega Predvajanja",
+ "disable": "Skrij Statistiko Pretočnega Predvajanja"
+ },
+ "manualRecording": {
+ "title": "Snemanje na Zahtevo",
+ "tips": "Začni ročni dogodek na podlagi nastavitev hranjenja posnetkov te kamere.",
+ "playInBackground": {
+ "label": "Predvajaj v ozadju",
+ "desc": "Omogočite to možnost, če želite nadaljevati s pretakanjem, ko je predvajalnik skrit."
+ },
+ "showStats": {
+ "label": "Prikaži Statistiko",
+ "desc": "Omogočite to možnost, če želite statistiko pretoka prikazati kot prekrivni sloj na viru kamere."
+ },
+ "debugView": "Pogled za Odpravljanje Napak",
+ "start": "Začni snemanje na zahtevo",
+ "started": "Začelo se je ročno snemanje na zahtevo.",
+ "failedToStart": "Ročnega snemanja na zahtevo ni bilo mogoče začeti.",
+ "recordDisabledTips": "Ker je snemanje v nastavitvah te kamere onemogočeno ali omejeno, bo shranjena samo slika.",
+ "end": "Končaj snemanje na zahtevo",
+ "ended": "Ročno snemanje na zahtevo je končano.",
+ "failedToEnd": "Ročnega snemanja na zahtevo ni bilo mogoče končati."
+ },
+ "streamingSettings": "Nastavitve Pretakanja",
+ "notifications": "Obvestila",
+ "audio": "Zvok",
+ "suspend": {
+ "forTime": "Začasno ustavi za: "
+ },
+ "stream": {
+ "title": "Pretok",
+ "audio": {
+ "tips": {
+ "title": "Zvok mora biti predvajan iz vaše kamere in konfiguriran v go2rtc za ta pretok.",
+ "documentation": "Preberi Dokumentacijo "
+ },
+ "available": "Za ta pretok je na voljo zvok",
+ "unavailable": "Zvok za ta pretok ni na voljo"
+ },
+ "twoWayTalk": {
+ "tips": "Vaša naprava mora podpirati to funkcijo, WebRTC pa mora biti konfiguriran za dvosmerni pogovor.",
+ "tips.documentation": "Preberi dokumentacijo ",
+ "available": "Za ta tok je na voljo dvosmerni pogovor",
+ "unavailable": "Dvosmerni pogovor ni na voljo za ta pretok"
+ },
+ "lowBandwidth": {
+ "tips": "Pogled v živo je v načinu nizke pasovne širine zaradi napak v nalaganju ali pretoku.",
+ "resetStream": "Ponastavi pretok"
+ },
+ "playInBackground": {
+ "label": "Predvajaj v ozadju",
+ "tips": "Omogočite to možnost, če želite nadaljevati s pretakanjem, ko je predvajalnik skrit."
}
+ },
+ "cameraSettings": {
+ "title": "{{camera}} Nastavitve",
+ "cameraEnabled": "Kamera Omogočena",
+ "objectDetection": "Zaznavanje Objektov",
+ "recording": "Snemanje",
+ "snapshots": "Slike",
+ "audioDetection": "Zvočna Detekcija",
+ "transcription": "Zvočni Prepis",
+ "autotracking": "Samodejno Sledenje"
+ },
+ "history": {
+ "label": "Prikaži stare posnetke"
+ },
+ "effectiveRetainMode": {
+ "modes": {
+ "all": "Vse",
+ "motion": "Gibanje",
+ "active_objects": "Aktivni Objekti"
+ },
+ "notAllTips": "Vaša konfiguracija hranjenja posnetkov {{source}} je nastavljena na način : {{effectiveRetainMode}}, zato bo ta posnetek na zahtevo hranil samo segmente z {{effectiveRetainModeName}}."
+ },
+ "editLayout": {
+ "label": "Uredi Postavitev",
+ "group": {
+ "label": "Uredi Skupino Kamere"
+ },
+ "exitEdit": "Izhod iz Urejanja"
}
}
diff --git a/web/public/locales/sl/views/search.json b/web/public/locales/sl/views/search.json
index b2233e1e4..16224e2aa 100644
--- a/web/public/locales/sl/views/search.json
+++ b/web/public/locales/sl/views/search.json
@@ -25,7 +25,8 @@
"has_clip": "Ima posnetek",
"max_speed": "Najvišja hitrost",
"min_speed": "Najnižja hitrost",
- "has_snapshot": "Ima sliko"
+ "has_snapshot": "Ima sliko",
+ "attributes": "Atributi"
},
"searchType": {
"thumbnail": "Sličica",
diff --git a/web/public/locales/sl/views/settings.json b/web/public/locales/sl/views/settings.json
index af8f70748..5b6de9a35 100644
--- a/web/public/locales/sl/views/settings.json
+++ b/web/public/locales/sl/views/settings.json
@@ -6,9 +6,12 @@
"notifications": "Nastavitve obvestil - Frigate",
"masksAndZones": "Urejevalnik mask in območij - Frigate",
"object": "Odpravljanje napak - Frigate",
- "general": "Splošne Nastavitve - Frigate",
+ "general": "Splošne nastavitve - Frigate",
"frigatePlus": "Frigate+ Nastavitve - Frigate",
- "enrichments": "Nastavitve Obogatitev - Frigate"
+ "enrichments": "Nastavitve Obogatitev - Frigate",
+ "motionTuner": "Nastavitev gibanja - Frigate",
+ "cameraManagement": "Upravljaj kamere - Frigate",
+ "cameraReview": "Nastavitve pregleda kamer – Frigate"
},
"menu": {
"ui": "Uporabniški vmesnik",
@@ -18,7 +21,12 @@
"debug": "Razhroščevanje",
"users": "Uporabniki",
"notifications": "Obvestila",
- "frigateplus": "Frigate+"
+ "frigateplus": "Frigate+",
+ "motionTuner": "Nastavitev Gibanja",
+ "triggers": "Prožilniki",
+ "cameraManagement": "Upravljanje",
+ "cameraReview": "Pregled",
+ "roles": "Vloge"
},
"masksAndZones": {
"zones": {
@@ -59,12 +67,345 @@
"desc": "Samodejno preklopite na pogled kamere v živo, ko je zaznana aktivnost. Če onemogočite to možnost, se statične slike kamere na nadzorni plošči v živo posodobijo le enkrat na minuto."
},
"playAlertVideos": {
- "label": "Predvajajte opozorilne videoposnetke"
+ "label": "Predvajajte opozorilne videoposnetke",
+ "desc": "Privzeto se nedavna opozorila na nadzorni plošči predvajajo kot kratki ponavljajoči videoposnetki . To možnost onemogočite, če želite, da se v tej napravi/brskalniku prikaže samo statična slika nedavnih opozoril."
+ },
+ "displayCameraNames": {
+ "label": "Vedno prikaži imena kamer"
}
},
"storedLayouts": {
"title": "Sharnjene Postavitve",
- "desc": "Postaviteve kamer v skupini kamer je mogoče povleči/prilagoditi. Položaji so shranjeni v lokalnem pomnilniku vašega brskalnika."
+ "desc": "Postaviteve kamer v skupini kamer je mogoče povleči/prilagoditi. Položaji so shranjeni v lokalnem pomnilniku vašega brskalnika.",
+ "clearAll": "Počisti Vse Postavitve"
+ },
+ "cameraGroupStreaming": {
+ "title": "Nastavitve Pretakanja Skupine Kamer",
+ "desc": "Nastavitve pretakanja za vsako skupino kamer so shranjene v lokalnem pomnilniku vašega brskalnika.",
+ "clearAll": "Počisti Vse Nastavitve Pretakanja"
+ },
+ "recordingsViewer": {
+ "title": "Pregledovalnik Posnetkov",
+ "defaultPlaybackRate": {
+ "label": "Privzeta Hitrost Predvajanja",
+ "desc": "Privzeta Hitrost Predvajanja za Shranjene Posnetke."
+ }
+ },
+ "calendar": {
+ "title": "Koledar",
+ "firstWeekday": {
+ "label": "Prvi dan v tednu",
+ "desc": "Dan, na katerega se začnejo tedni v koledarju za preglede.",
+ "sunday": "Nedelja",
+ "monday": "Ponedeljek"
+ }
+ },
+ "toast": {
+ "success": {
+ "clearStoredLayout": "Shranjena postavitev za {{cameraName}} je bila izbrisana",
+ "clearStreamingSettings": "Nastavitve pretakanja za vse skupine kamer so bile izbrisane."
+ },
+ "error": {
+ "clearStoredLayoutFailed": "Shranjene postavitve ni bilo mogoče izbrisati: {{errorMessage}}",
+ "clearStreamingSettingsFailed": "Nastavitev pretakanja ni bilo mogoče izbrisati: {{errorMessage}}"
+ }
+ }
+ },
+ "enrichments": {
+ "title": "Nastavitve Obogatitev",
+ "unsavedChanges": "Neshranjene Spremembe Nastavitev Obogatitev",
+ "birdClassification": {
+ "title": "Klasifikacija ptic",
+ "desc": "Klasifikacija ptic identificira znane ptice z uporabo kvantiziranega Tensorflow modela. Ko je znana ptica prepoznana, se njeno splošno ime doda kot podoznaka. Te informacije so vključene v uporabniški vmesnik, filtre in obvestila."
+ },
+ "semanticSearch": {
+ "title": "Semantično Iskanje",
+ "desc": "Semantično iskanje v Frigate vam omogoča iskanje sledenih objektov znotraj vaših pregledov, pri čemer lahko uporabite izvorno sliko, uporabniško določen besedilni opis ali samodejno ustvarjen opis.",
+ "readTheDocumentation": "Preberi Dokumentacijo",
+ "reindexNow": {
+ "label": "Ponovno Indeksiraj Zdaj",
+ "desc": "Ponovno indeksiranje bo regeneriralo vdelave (embeddings) za vse sledene objekte. Ta postopek se izvaja v ozadju in lahko zelo obremeni vaš procesor ter traja precej časa, odvisno od števila sledenih objektov, ki jih imate.",
+ "confirmTitle": "Potrdi Ponovno Indeksiranje",
+ "confirmDesc": "Ali ste prepričani, da želite ponovno indeksirati vse vdelave (embeddings) sledenih objektov? Ta postopek se bo izvajal v ozadju, vendar lahko zelo obremeni vaš procesor in traja kar nekaj časa. Napredek si lahko ogledate na strani Razišči.",
+ "confirmButton": "Ponovno Indeksiranje",
+ "success": "Ponovno indeksiranje se je uspešno začelo.",
+ "alreadyInProgress": "Ponovno indeksiranje je že v teku.",
+ "error": "Ponovnega indeksiranja ni bilo mogoče začeti: {{errorMessage}}"
+ },
+ "modelSize": {
+ "label": "Velikost Modela",
+ "desc": "Velikost modela, uporabljenega za vdelave (embeddings) semantičnih iskanj.",
+ "small": {
+ "title": "majhen",
+ "desc": "Uporaba načina small uporablja kvantizirano različico modela, ki porabi manj RAM-a in deluje hitreje na procesorju z zelo zanemarljivo razliko v kakovosti vdelave (embedding)."
+ },
+ "large": {
+ "title": "velik",
+ "desc": "Uporaba možnosti large uporablja celoten model Jina in se bo, če je mogoče, samodejno izvajal na grafičnem procesorju."
+ }
+ }
+ },
+ "faceRecognition": {
+ "title": "Prepoznavanje Obrazov",
+ "desc": "Prepoznavanje obrazov omogoča, da se ljudem dodelijo imena, in ko Frigate prepozna njihov obraz, se detekciji dodeli ime kot podoznako. Te informacije so vključene v uporabniški vmesnik, filtre in obvestila.",
+ "readTheDocumentation": "Preberi Dokumentacijo",
+ "modelSize": {
+ "label": "Velikost Modela",
+ "desc": "Velikost modela, uporabljenega za prepoznavanje obrazov.",
+ "small": {
+ "title": "majhen",
+ "desc": "Uporaba small uporablja model vdelave (embedding) obrazov FaceNet, ki učinkovito deluje na večini procesorjev."
+ },
+ "large": {
+ "title": "velik",
+ "desc": "Uporaba large uporablja model vdelave (embedding) obrazov ArcFace in se bo samodejno zagnala na grafičnem procesorju, če bo to mogoče."
+ }
+ }
+ },
+ "licensePlateRecognition": {
+ "title": "Prepoznavanje Registrskih Tablic",
+ "desc": "Frigate lahko prepozna registrske tablice na vozilih in samodejno doda zaznane znake v polje recognized_license_plate ali znano ime kot podoznako objektom tipa car. Pogost primer uporabe je lahko branje registrskih tablic avtomobilov, ki se ustavijo na dovozu, ali avtomobilov, ki se peljejo mimo po ulici.",
+ "readTheDocumentation": "Preberi Dokumentacijo"
+ },
+ "restart_required": "Potreben je ponovni zagon (Nastavitve Obogatitve so bile spremenjene)",
+ "toast": {
+ "success": "Nastavitve Obogatitev so shranjene. Znova zaženite Frigate, da uveljavite spremembe.",
+ "error": "Shranjevanje sprememb konfiguracije ni uspelo: {{errorMessage}}"
+ }
+ },
+ "camera": {
+ "title": "Nastavitve Kamere",
+ "streams": {
+ "title": "Pretoki"
+ },
+ "object_descriptions": {
+ "title": "Opisi objektov z uporabo generativne UI",
+ "desc": "Začasno omogoči/onemogoči opise objektov z uporabo generativne UI za to kamero. Ko so onemogočeni, opisi, ki jih ustvari UI, ne bodo zahtevani za sledene objekte na tej kameri."
+ },
+ "review": {
+ "title": "Pregled",
+ "desc": "Začasno omogoči/onemogoči opozorila in zaznavanja za to kamero, dokler se Frigate ne zažene znova. Ko je onemogočeno, ne bodo ustvarjeni novi elementi pregleda. ",
+ "alerts": "Opozorila ",
+ "detections": "Detekcije "
+ },
+ "reviewClassification": {
+ "title": "Pregled Klasifikacij",
+ "readTheDocumentation": "Preberi Dokumentacijo",
+ "noDefinedZones": "Za to kamero ni določenih nobenih con.",
+ "objectAlertsTips": "Vsi objekti {{alertsLabels}} na {{cameraName}} bodo prikazani kot Opozorila.",
+ "unsavedChanges": "Neshranjene nastavitve Pregleda Klasifikacije za {{camera}}",
+ "selectAlertsZones": "Izberite cone za Opozorila",
+ "selectDetectionsZones": "Izberite cone za Zaznavanje",
+ "limitDetections": "Omejite zaznavanje na določene cone"
+ },
+ "addCamera": "Dodaj Novo Kamero",
+ "editCamera": "Uredi Kamero:",
+ "selectCamera": "Izberi Kamero",
+ "backToSettings": "Nazaj na Nastavitve Kamere",
+ "cameraConfig": {
+ "add": "Dodaj Kamero",
+ "edit": "Uredi Kamero",
+ "description": "Konfigurirajte nastavitve kamere, vključno z pretočnimi vhodi in vlogami.",
+ "name": "Ime Kamere",
+ "nameRequired": "Ime kamere je obvezno",
+ "nameInvalid": "Ime kamere mora vsebovati samo črke, številke, podčrtaje ali vezaje",
+ "namePlaceholder": "npr. vhodna_vrata"
+ }
+ },
+ "cameraWizard": {
+ "title": "Dodaj kamero",
+ "description": "Sledi spodnjim korakom, da dodaš novo kamero v svojo namestitev Frigate.",
+ "steps": {
+ "nameAndConnection": "Ime & Zbirka",
+ "streamConfiguration": "Konfiguracija pretoka",
+ "validationAndTesting": "Uverjanje in testiranje"
+ },
+ "save": {
+ "success": "Kamera {{cameraName}} je bila uspešno shranjena.",
+ "failure": "Napaka pri shranjevanju {{cameraName}}."
+ },
+ "testResultLabels": {
+ "resolution": "Resolucija",
+ "video": "Video",
+ "audio": "Zvok",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Prosimo, vnesite veljaven URL pretoka",
+ "testFailed": "Preizkus pretoka ni uspel: {{error}}"
+ },
+ "step1": {
+ "description": "Vnesite podatke o kameri in izberite, ali želite kamero zaznati samodejno ali ročno izbrati blagovno znamko.",
+ "cameraName": "Ime kamere",
+ "cameraNamePlaceholder": "npr. sprednja_vrata ali Pregled zadnjega dvorišča",
+ "host": "Gostitelj/IP naslov",
+ "port": "Vrata",
+ "username": "Uporabniško ime",
+ "usernamePlaceholder": "Opcijsko",
+ "password": "Geslo",
+ "passwordPlaceholder": "Opcijsko",
+ "selectTransport": "Izberi transportni protokol",
+ "cameraBrand": "Znamka kamere",
+ "selectBrand": "Izberi znamko kamere za predlogo URL-ja",
+ "customUrl": "Po meri URL za pretok",
+ "brandInformation": "Informacije o znamki",
+ "brandUrlFormat": "Za kamere z obliko URL-ja RTSP: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://uporabniškoime:geslo@gostitelj:vrata/pot",
+ "testConnection": "Preveri povezavo",
+ "testSuccess": "Test povezave uspešen!",
+ "testFailed": "Test povezave neuspešen. Prosim preveri vnos in poskusi še enkrat.",
+ "streamDetails": "Podrobnosti pretoka",
+ "testing": {
+ "probingMetadata": "Preiskovanje metapodatkov kamere...",
+ "fetchingSnapshot": "Pridobivanje posnetka kamere..."
+ },
+ "warnings": {
+ "noSnapshot": "Ni mogoče pridobiti posnetka iz nastavljenega pretoka."
+ },
+ "errors": {
+ "nameLength": "Ime kamere mora biti 64 znakov ali manj",
+ "invalidCharacters": "Ime kamere vsebuje neveljavne znake",
+ "nameExists": "Ime kamere že obstaja",
+ "customUrlRtspRequired": "URL-ji po meri se morajo začeti z \"rtsp://\". Za ne-RTSP pretoke kamer je potrebna ročna nastavitev.",
+ "brands": {
+ "reolink-rtsp": "RTSP za Reolink ni priporočen. \nV nastavitvah kamere omogočite HTTP in znova zaženite čarovnika."
+ }
+ }
+ },
+ "step2": {
+ "streamUrlPlaceholder": "rtsp://uporabniskoime:geslo@gostitelj:vrata/pot",
+ "url": "URL",
+ "resolution": "Resolucija",
+ "selectResolution": "Izberi resolucijo",
+ "quality": "Kvaliteta",
+ "selectQuality": "Izberi kvaliteto",
+ "roles": "Vloge",
+ "roleLabels": {
+ "detect": "Prepoznavanje objektov",
+ "record": "Snemanje",
+ "audio": "Zvok"
+ },
+ "testStream": "Preveri povezavo",
+ "testSuccess": "Test povezave je bil uspešen!",
+ "testFailed": "Test povezave ni bil uspešen. Preverite nastavitve in poskusite znova.",
+ "testFailedTitle": "Test spodletel",
+ "connected": "Povezan",
+ "notConnected": "Ni povezave",
+ "featuresTitle": "Funkcije",
+ "go2rtc": "Zmanjšaj povezave na kamero",
+ "detectRoleWarning": "Vsaj en pretok mora imeti vlogo »zaznavanje«, da lahko nadaljuješ.",
+ "rolesPopover": {
+ "title": "Vloge pretoka",
+ "detect": "Glavni vir za zaznavanje objektov.",
+ "record": "Shranjuje odseke video posnetka glede na nastavitve konfiguracije.",
+ "audio": "Vir za zaznavanje na podlagi zvoka."
+ },
+ "featuresPopover": {
+ "title": "Značilnosti pretoka",
+ "description": "Uporabi ponovno pretakanje go2rtc, da zmanjšaš število povezav s kamero."
+ }
+ },
+ "step3": {
+ "description": "Konfigurirajte vloge tokov in dodajte dodatne tokove za vašo kamero.",
+ "validationTitle": "Preverjanje pretoka",
+ "connectAllStreams": "Poveži vse pretoke",
+ "reconnectionSuccess": "Ponovna povezava uspešna.",
+ "reconnectionPartial": "Nekateri pretoki se niso ponovno povezali.",
+ "streamUnavailable": "Predogled pretoka ni na voljo",
+ "reload": "Ponovno naloži",
+ "connecting": "Povezujem...",
+ "streamTitle": "Pretok {{number}}",
+ "valid": "Veljaven",
+ "failed": "Spodletel",
+ "notTested": "Ni testiran",
+ "connectStream": "Poveži",
+ "connectingStream": "Povezujem",
+ "disconnectStream": "Prekini povezavo",
+ "estimatedBandwidth": "Predvidena pasovna širina",
+ "roles": "Vloge",
+ "none": "Noben",
+ "error": "Napaka",
+ "streamValidated": "Pretok {{number}} uspešno preverjen",
+ "streamValidationFailed": "Preverjanje pretoka {{number}} spodletelo",
+ "saveAndApply": "Shrani novo kamero",
+ "saveError": "Neveljavna konfiguracija. Prosimo preverite vaše nastavitve.",
+ "issues": {
+ "title": "Preverjanje pretoka",
+ "videoCodecGood": "Video kodek je {{codec}}.",
+ "audioCodecGood": "Audio kodek je {{codec}}.",
+ "resolutionHigh": "Resolucija {{resolution}} lahko povzroči povečano porabo virov."
+ }
+ }
+ },
+ "roles": {
+ "toast": {
+ "success": {
+ "userRolesUpdated_one": "{{count}} uporabnik, dodeljen tej vlogi, je bil posodobljen na »gledalec«, ki ima dostop do vseh kamer.",
+ "userRolesUpdated_two": "{{count}} uporabnika, dodeljena tej vlogi, sta bila posodobljena na »gledalec«, ki ima dostop do vseh kamer.",
+ "userRolesUpdated_few": "{{count}} uporabniki, dodeljeni tej vlogi, so bili posodobljeni na »gledalec«, ki ima dostop do vseh kamer.",
+ "userRolesUpdated_other": "{{count}} uporabnikov, dodeljenih tej vlogi, so bili posodobljeni na »gledalec«, ki ima dostop do vseh kamer."
+ }
+ }
+ },
+ "triggers": {
+ "toast": {
+ "error": {
+ "createTriggerFailed": "Napaka pri ustvarjanju sprožilca: {{errorMessage}}"
+ },
+ "success": {
+ "deleteTrigger": "Sprožilec {{name}} je bil uspešno odstranjen.",
+ "updateTrigger": "Sprožilec {{name}} je bil uspešno posodobljen.",
+ "createTrigger": "Sprožilec {{name}} je bil uspešno ustvarjen."
+ }
+ },
+ "wizard": {
+ "steps": {
+ "thresholdAndActions": "Mejne vrednosti in dejanja",
+ "configureData": "Nastavitve podatkov",
+ "nameAndType": "Ime in tip"
+ },
+ "step3": {
+ "description": "Konfigurirajte mejno vrednost in dejanja za ta sprožilec."
+ },
+ "step2": {
+ "description": "Konfigurirajte vsebino sprožilca, da se bo akcija izvedla."
+ },
+ "step1": {
+ "description": "Konfigurirajte osnovne nastavitve sprožilca."
+ },
+ "title": "Ustvarite sprožilec"
+ },
+ "dialog": {
+ "form": {
+ "actions": {
+ "error": {
+ "min": "Vsaj ena akcija mora biti izbrana."
+ },
+ "desc": "Privzeto Frigate pošlje MQTT sporočilo za vse sprožilce. Podnalepke dodajo ime sprožilca oznaki objekta. Atributi so iskalni metapodatki, shranjeni ločeno v metapodatkih sledenega objekta.",
+ "title": "Akcije"
+ },
+ "threshold": {
+ "error": {
+ "max": "Mejna vrednost ne sme presegati 1",
+ "min": "Mena vrednost mora biti vsaj 0"
+ },
+ "desc": "Nastavite mejno vrednost podobnosti za ta sprožilec. Višja mejna vrednost pomeni, da je za sprožitev potrebna večja ujemanje.",
+ "title": "Mejna vrednost"
+ },
+ "content": {
+ "error": {
+ "required": "Vsebina je zahtevana."
+ },
+ "textDesc": "Vnesite besedilo, ki bo sprožilo to dejanje, ko bo zaznan opis podobnega sledenega objekta.",
+ "imageDesc": "Prikazanih je le zadnjih 100 sličic. Če ne najdete želene sličice, si oglejte starejše objekte v razdelku Razišči in tam nastavite sprožilec iz menija.",
+ "textPlaceholder": "Vnesite besedilo",
+ "imagePlaceholder": "Izberite sličico",
+ "title": "Vsebina"
+ },
+ "type": {
+ "thumbnail": "Sproži, ko je zaznana podobna sličica sledenega objekta"
+ }
+ }
}
}
}
diff --git a/web/public/locales/sl/views/system.json b/web/public/locales/sl/views/system.json
index 4a19721c0..684492cf7 100644
--- a/web/public/locales/sl/views/system.json
+++ b/web/public/locales/sl/views/system.json
@@ -7,7 +7,8 @@
"frigate": "Frigate dnevniki - Frigate",
"go2rtc": "Go2RTC dnevniki - Frigate",
"nginx": "Nginx dnevniki - Frigate"
- }
+ },
+ "enrichments": "Statistika Obogatitev - Frigate"
},
"logs": {
"download": {
@@ -23,6 +24,13 @@
"timestamp": "Časovni žig",
"message": "Sporočilo",
"tag": "Oznaka"
+ },
+ "tips": "Dnevniki se pretakajo s strežnika",
+ "toast": {
+ "error": {
+ "fetchingLogsFailed": "Napaka pri pridobivanju dnevnikov: {{errorMessage}}",
+ "whileStreamingLogs": "Napaka med pretakanjem dnevnikov: {{errorMessage}}"
+ }
}
},
"storage": {
@@ -44,6 +52,10 @@
"title": "Neporabljeno",
"tips": "Ta vrednost ne predstavlja dejanske proste kapacitete za Frigate posnetke, če na disku shranjujete še druge datoteke. Frigate ne spremlja velikost drugih datotek na disku."
}
+ },
+ "shm": {
+ "warning": "Trenutna SHM velikost {{total}}MB je premajhna. Povečajte jo na vsaj {{min_shm}}MB.",
+ "title": "SHM (deljen pomnilnik) razdelitev"
}
},
"general": {
@@ -78,7 +90,12 @@
"success": "GPU informacije kopirane v odložišče"
}
},
- "npuUsage": "Poraba NPE"
+ "npuUsage": "Poraba NPE",
+ "intelGpuWarning": {
+ "message": "GPU status nerazpoložljiv",
+ "description": "To je znana napaka v orodjih za poročanje statistike Intelovega GPU-ja (intel_gpu_top), kjer se orodje pokvari in ponavljajoče javlja 0 % uporabe GPU-ja, tudi kadar strojna pospešitev in detekcija objektov pravilno tečeta na (i)GPU-ju. To ni napaka v Frigateu. Lahko ponovno zaženeš gostitelja (host), da začasno odpraviš težavo in potrdiš, da GPU dejansko deluje pravilno. Na zmogljivost to ne vpliva.",
+ "title": "Opozorilo statistike Intel GPU-ja"
+ }
},
"title": "Splošno",
"detector": {
@@ -86,12 +103,20 @@
"inferenceSpeed": "Hitrost sklepanja detektorja",
"temperature": "Temperatura detektorja",
"cpuUsage": "Poraba CPE detektorja",
- "memoryUsage": "Poraba pomnilnika detektorja"
+ "memoryUsage": "Poraba pomnilnika detektorja",
+ "cpuUsageInformation": "CPU poraba pri pripravi vhodnih in izhodnih podatkov za / iz modelov za detekcijo. Ta vrednost ne meri porabe pri sami inferenci (izvajanju modela), tudi če uporabljaš GPU ali kakšen drug pospeševalnik."
},
"otherProcesses": {
"title": "Ostali procesi",
"processMemoryUsage": "Poraba pomnilnika",
- "processCpuUsage": "Poraba CPE"
+ "processCpuUsage": "Poraba CPE",
+ "series": {
+ "go2rtc": "go2rtc",
+ "recording": "snemanje",
+ "audio_detector": "detektor zvoka",
+ "review_segment": "preglej segment",
+ "embeddings": "vdelave"
+ }
}
},
"title": "Sistem",
@@ -100,7 +125,84 @@
"title": "Kamere",
"overview": "Pregled",
"info": {
- "aspectRatio": "razmerje stranic"
+ "aspectRatio": "razmerje stranic",
+ "cameraProbeInfo": "{{camera}} Podrobne Informacije Kamere",
+ "streamDataFromFFPROBE": "Podatki o pretoku se pridobijo z ukazom ffprobe.",
+ "fetching": "Pridobivanje Podatkov Kamere",
+ "stream": "Pretok {{idx}}",
+ "video": "Video:",
+ "codec": "Kodek:",
+ "resolution": "Ločljivost:",
+ "fps": "FPS:",
+ "unknown": "Neznano",
+ "audio": "Zvok:",
+ "error": "Napaka: {{error}}",
+ "tips": {
+ "title": "Podrobne Informacije Kamere"
+ }
+ },
+ "framesAndDetections": "Okvirji / Zaznave",
+ "label": {
+ "camera": "kamera",
+ "detect": "zaznaj",
+ "skipped": "preskočeno",
+ "ffmpeg": "FFmpeg",
+ "capture": "zajemanje",
+ "overallFramesPerSecond": "skupno število sličic na sekundo (FPS)",
+ "overallDetectionsPerSecond": "skupno število zaznav na sekundo",
+ "overallSkippedDetectionsPerSecond": "skupno število preskočenih zaznav na sekundo",
+ "cameraFfmpeg": "{{camName}} FFmpeg",
+ "cameraCapture": "{{camName}} zajem",
+ "cameraDetect": "{{camName}} zaznavanje",
+ "cameraFramesPerSecond": "{{camName}} sličic na sekundo (FPS)",
+ "cameraDetectionsPerSecond": "{{camName}} detekcij na sekundo",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} preskočenih zaznav na sekundo"
+ },
+ "toast": {
+ "success": {
+ "copyToClipboard": "Podatki sonde so bili kopirani v odložišče."
+ },
+ "error": {
+ "unableToProbeCamera": "Ni mogoče preveriti podrobnosti kamere: {{errorMessage}}"
+ }
}
+ },
+ "lastRefreshed": "Zadnja osvežitev: ",
+ "stats": {
+ "ffmpegHighCpuUsage": "{{camera}} ima visoko porabo procesorja FFmpeg ({{ffmpegAvg}} %)",
+ "detectHighCpuUsage": "{{camera}} ima visoko porabo procesorja za zaznavanje ({{detectAvg}} %)",
+ "healthy": "Sistem je zdrav",
+ "reindexingEmbeddings": "Ponovno indeksiranje vdelanih elementov (embeddings) ({{processed}}% končano)",
+ "cameraIsOffline": "{{camera}} je nedosegljiva",
+ "detectIsSlow": "{{detect}} je počasen ({{speed}} ms)",
+ "detectIsVerySlow": "{{detect}} je zelo počasen ({{speed}} ms)",
+ "shmTooLow": "/dev/shm direktorij({{total}} MB) bi moral imeti vsaj {{min}} MB."
+ },
+ "enrichments": {
+ "title": "Obogatitve",
+ "infPerSecond": "Inference Na Sekundo",
+ "embeddings": {
+ "face_recognition": "Prepoznavanje Obrazov",
+ "plate_recognition": "Prepoznavanje Registrskih Tablic",
+ "face_recognition_speed": "Hitrost Prepoznavanja Obrazov",
+ "plate_recognition_speed": "Hitrost Prepoznavanja Registrskih Tablic",
+ "yolov9_plate_detection": "YOLOv9 Zaznavanje Registrskih Tablic",
+ "image_embedding": "Vdelava slik",
+ "text_embedding": "Vdelava besedila",
+ "image_embedding_speed": "Hitrost vdelave slik",
+ "yolov9_plate_detection_speed": "Hitrost zaznavanja tablic YOLOv9",
+ "review_description": "Opis pregleda",
+ "review_description_speed": "Preverite hitrost opisa",
+ "classification": "Klasifikacija {{name}}",
+ "classification_speed": "Hitrost klasificiranja {{name}}",
+ "classification_events_per_second": "Hitrost klasificiranja dogodkov {{name}} na sekundo",
+ "face_embedding_speed": "Hitrost vdelave obrazov",
+ "text_embedding_speed": "Hitrost vdelave besedila",
+ "review_description_events_per_second": "Opis pregleda",
+ "object_description": "Opis objekta",
+ "object_description_speed": "Hitrost opisa objekta",
+ "object_description_events_per_second": "Opis objekta"
+ },
+ "averageInf": "Povprečen čas inference"
}
}
diff --git a/web/public/locales/sr/audio.json b/web/public/locales/sr/audio.json
index a9e52ade6..fea4e3e77 100644
--- a/web/public/locales/sr/audio.json
+++ b/web/public/locales/sr/audio.json
@@ -11,5 +11,57 @@
"whispering": "Šaptanje",
"bus": "Autobus",
"laughter": "Smeh",
- "train": "Voz"
+ "train": "Voz",
+ "boat": "Brod",
+ "crying": "Plač",
+ "sigh": "Уздах",
+ "singing": "Пријављивање",
+ "choir": "Збор",
+ "yodeling": "Јодловање",
+ "chant": "Певање",
+ "mantra": "Мантра",
+ "bird": "Птица",
+ "snicker": "Кикот",
+ "child_singing": "Дечје певање",
+ "cat": "Мачка",
+ "synthetic_singing": "Синтетичко певање",
+ "dog": "Пас",
+ "rapping": "Реповање",
+ "horse": "Коњ",
+ "humming": "Брундање",
+ "sheep": "Овца",
+ "groan": "Стењање",
+ "grunt": "Мрмљање",
+ "whistling": "Звиждање",
+ "breathing": "Дисање",
+ "wheeze": "Шиштање",
+ "snoring": "Хркање",
+ "gasp": "Задиханост",
+ "pant": "Задиханост",
+ "snort": "Шмркање",
+ "cough": "Кашаљ",
+ "throat_clearing": "Прочишћавање грла",
+ "sneeze": "Кијање",
+ "sniff": "Њушкање",
+ "run": "Трчање",
+ "shuffle": "Насумично",
+ "footsteps": "Корачање",
+ "chewing": "Жвакање",
+ "biting": "Угриз",
+ "gargling": "Гргорење",
+ "stomach_rumble": "Крчање стомака",
+ "camera": "Камера",
+ "burping": "Подригивање",
+ "skateboard": "Скејтборд",
+ "hiccup": "Штуцање",
+ "fart": "Прдеж",
+ "hands": "Руке",
+ "finger_snapping": "Пуцање прстима",
+ "clapping": "Пљескање",
+ "heartbeat": "Откуцаји срца",
+ "cheering": "Навијање",
+ "applause": "Аплауз",
+ "chatter": "Жамор",
+ "crowd": "Маса",
+ "children_playing": "Деца се играју"
}
diff --git a/web/public/locales/sr/common.json b/web/public/locales/sr/common.json
index a68b33248..1408ef405 100644
--- a/web/public/locales/sr/common.json
+++ b/web/public/locales/sr/common.json
@@ -23,9 +23,57 @@
"pm": "pm",
"am": "am",
"yr": "{{time}}god",
- "year_one": "1,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21...",
- "year_few": "2,3,4,22,23,24,32,33,34,42,...",
- "year_other": "",
- "mo": "{{time}}mes"
- }
+ "year_one": "{{time}} година",
+ "year_few": "{{time}} године",
+ "year_other": "{{time}} година",
+ "mo": "{{time}}mes",
+ "month_one": "{{time}} месец",
+ "month_few": "{{time}} месеца",
+ "month_other": "{{time}} месеци",
+ "d": "{{time}}d",
+ "day_one": "{{time}} дан",
+ "day_few": "{{time}} дана",
+ "day_other": "{{time}} дана",
+ "h": "{{time}}h",
+ "hour_one": "{{time}} сат",
+ "hour_few": "{{time}} сата",
+ "hour_other": "{{time}} сати",
+ "m": "{{time}}m",
+ "minute_one": "{{time}} минут",
+ "minute_few": "{{time}} минута",
+ "minute_other": "{{time}} минута",
+ "s": "{{time}}s",
+ "second_one": "{{time}} секунда",
+ "second_few": "{{time}} секунде",
+ "second_other": "{{time}} секунди",
+ "formattedTimestampHourMinute": {
+ "24hour": "HH:mm"
+ },
+ "formattedTimestampHourMinuteSecond": {
+ "12hour": "h:mm:ss aaa",
+ "24hour": "HH:mm:ss"
+ },
+ "formattedTimestampMonthDayHourMinute": {
+ "12hour": "MMM d, h:mm aaa",
+ "24hour": "MMM d, HH:mm"
+ },
+ "formattedTimestampMonthDayYear": {
+ "12hour": "MMM d, yyyy",
+ "24hour": "MMM d, yyyy"
+ },
+ "formattedTimestampMonthDayYearHourMinute": {
+ "12hour": "MMM d yyyy, h:mm aaa",
+ "24hour": "MMM d yyyy, HH:mm"
+ },
+ "formattedTimestamp": {
+ "12hour": "MMM d, h:mm:ss aaa",
+ "24hour": "MMM d, HH:mm:ss"
+ },
+ "formattedTimestampMonthDay": "MMM d",
+ "formattedTimestampFilename": {
+ "12hour": "MM-dd-yy-h-mm-ss-a",
+ "24hour": "MM-dd-yy-HH-mm-ss"
+ }
+ },
+ "readTheDocumentation": "Прочитајте документацију"
}
diff --git a/web/public/locales/sr/components/auth.json b/web/public/locales/sr/components/auth.json
index f601ec61a..177b293e7 100644
--- a/web/public/locales/sr/components/auth.json
+++ b/web/public/locales/sr/components/auth.json
@@ -7,7 +7,10 @@
"usernameRequired": "Korisničko ime je obavezno",
"passwordRequired": "Lozinka je obavezna",
"rateLimit": "Prekoračeno ograničenje brzine. Pokušajte ponovo kasnije.",
- "loginFailed": "Prijava nije uspela"
- }
+ "loginFailed": "Prijava nije uspela",
+ "unknownError": "Nepoznata greška. Proveri logove.",
+ "webUnknownError": "Nepoznata greška. Proveri logove u konzoli."
+ },
+ "firstTimeLogin": "Пријављујете се по први пут? Креденцијали су одштампани у логовима Фригејта."
}
}
diff --git a/web/public/locales/sr/components/camera.json b/web/public/locales/sr/components/camera.json
index 6be8272ec..b5e9c5fee 100644
--- a/web/public/locales/sr/components/camera.json
+++ b/web/public/locales/sr/components/camera.json
@@ -11,7 +11,76 @@
}
},
"name": {
- "label": "Ime"
+ "label": "Ime",
+ "placeholder": "Unesite ime…",
+ "errorMessage": {
+ "mustLeastCharacters": "Naziv grupe kamera mora imati bar 2 karaktera.",
+ "exists": "Група камера са тим именом већ постоји.",
+ "nameMustNotPeriod": "Назив групе камера не сме да садржи запету.",
+ "invalid": "Назив групе камера није исправан."
+ }
+ },
+ "cameras": {
+ "label": "Камере",
+ "desc": "Изаберите камере за ову групу."
+ },
+ "icon": "Иконица",
+ "success": "Група камера ({{name}}) је сачувана.",
+ "camera": {
+ "birdseye": "Птичије око",
+ "setting": {
+ "label": "Подешавање стримовања камере",
+ "title": "{{cameraName}} подешавања стримовања",
+ "desc": "Промена опција за стримовање уживо за контролну таблу групе камера. Ова подешавања су везана за уређај/браузер.",
+ "audioIsAvailable": "Звук је доступан у овом стриму",
+ "audioIsUnavailable": "Звук није доступан за овај стрим",
+ "audio": {
+ "tips": {
+ "title": "Звук мора бити излаз из ваше камере и подешен у go2rtc за овај стрим."
+ }
+ },
+ "stream": "Стрим",
+ "placeholder": "Изаберите стрим",
+ "streamMethod": {
+ "label": "Метод стриминга",
+ "placeholder": "Изаберите метод стриминга",
+ "method": {
+ "noStreaming": {
+ "label": "Нема стриминга",
+ "desc": "Слике камере ће бити ажуриране једном у минуту и неће се приказати стриминг уживо."
+ },
+ "smartStreaming": {
+ "label": "Паметан стриминг (препоручено)",
+ "desc": "Паметан стриминг ће ажурирати слике камере једном у минуту, када нема детектоване активности, да би се уштедело на мрежном саобраћају и ресурсима. Када је детектована активност, слика ће аутоматски прећи на стриминг уживо."
+ },
+ "continuousStreaming": {
+ "label": "Непрекидно стримовање",
+ "desc": {
+ "title": "Слика камере ће увек бити стрим уживо када је видљива на контролној табли, чак и када активност није детектована.",
+ "warning": "Непрекидно стримовање може проузроковати високу употребу мрежу и проблеме са перформансама. Користити опрезно."
+ }
+ }
+ }
+ },
+ "compatibilityMode": {
+ "label": "Режим компатибилности",
+ "desc": "Омогућите ову опцију само ако репродукција стрима уживо на камери приказује обојене артифекте и има дијагоналну линију на десној страни слице."
+ }
+ }
}
+ },
+ "debug": {
+ "options": {
+ "label": "Подешавања",
+ "title": "Опције",
+ "showOptions": "Приказ опција",
+ "hideOptions": "Скривање опција"
+ },
+ "boundingBox": "Оквир",
+ "timestamp": "Временски тренутак",
+ "zones": "Зоне",
+ "mask": "Маска",
+ "motion": "Покрет",
+ "regions": "Региони"
}
}
diff --git a/web/public/locales/sr/components/dialog.json b/web/public/locales/sr/components/dialog.json
index 8c5a7c1c4..a97f7c4b6 100644
--- a/web/public/locales/sr/components/dialog.json
+++ b/web/public/locales/sr/components/dialog.json
@@ -13,7 +13,106 @@
"submitToPlus": {
"label": "Pošalji na Frigate+",
"desc": "Objekti na lokacijama koje želite da izbegnete nisu lažno pozitivni. Slanje lažno pozitivnih rezultata će zbuniti model."
+ },
+ "review": {
+ "question": {
+ "ask_a": "Da li je ovaj objekat {{label}}?",
+ "label": "Потврдите ову ознаку за Фригејт+",
+ "ask_an": "Да ли је овај објекат {{label}}?",
+ "ask_full": "Да ли је овај објекат {{untranslatedLabel}} ({{translatedLabel}})?"
+ },
+ "state": {
+ "submitted": "Послато"
+ }
+ }
+ },
+ "video": {
+ "viewInHistory": "Преглед у историји"
+ }
+ },
+ "export": {
+ "time": {
+ "fromTimeline": "Изаберите са временске линије",
+ "lastHour_one": "Последњи {{count}} сат",
+ "lastHour_few": "Последња {{count}} сата",
+ "lastHour_other": "Последњих {{count}} сати",
+ "custom": "Прилагођено",
+ "start": {
+ "title": "Почетно време",
+ "label": "Изаберите почетно време"
+ },
+ "end": {
+ "title": "Коначно време",
+ "label": "Изаберите завршно време"
+ }
+ },
+ "name": {
+ "placeholder": "Назив извоза"
+ },
+ "select": "Избор",
+ "export": "Извоз",
+ "selectOrExport": "Избор или извоз",
+ "toast": {
+ "success": "Извоз је успешно започет. Прегледајте фајл на страници са извозима.",
+ "view": "Преглед",
+ "error": {
+ "failed": "Неуспешан почетак извоза: {{error}}",
+ "endTimeMustAfterStartTime": "Завршно време мора бити након почетног времена",
+ "noVaildTimeSelected": "Није изабран валидан временски распон"
+ }
+ },
+ "fromTimeline": {
+ "saveExport": "Чување извоза",
+ "previewExport": "Преглед извоза"
+ }
+ },
+ "streaming": {
+ "label": "Стрим",
+ "restreaming": {
+ "disabled": "Поновни стриминг није омогућен за ову камеру.",
+ "desc": {
+ "title": "Подесите go2rtc за додатне опције репродукције слике и звука уживо за ову камеру."
+ }
+ },
+ "showStats": {
+ "label": "Приказ статистике стримовања",
+ "desc": "Омогућите ову опцију за приказ статистике стримовања као надслој на преноса са камере."
+ },
+ "debugView": "Приказ за дебаговање"
+ },
+ "search": {
+ "saveSearch": {
+ "label": "Сачувати претрагу",
+ "desc": "Обезбедите назив за ову сачувану претрагу.",
+ "placeholder": "Унесите име за вашу претрагу",
+ "overwrite": "{{searchName}} већ постоји. Чување ће преписати постојећу вредност.",
+ "success": "Претрага ({{searchName}}) је сачувана.",
+ "button": {
+ "save": {
+ "label": "Чување ове претраге"
+ }
}
}
+ },
+ "recording": {
+ "confirmDelete": {
+ "title": "Потврдите брисање",
+ "desc": {
+ "selected": "Да ли сте сигурни да желите да обришете све видео снимке повезане са овом ставком?
Држите притиснут Shift тастер да прескочите овај дијалог у будућности."
+ },
+ "toast": {
+ "success": "Видео снимак повезан са изабраним ставкама за преглед успешно је обрисан.",
+ "error": "Неуспешно брисање: {{error}}"
+ }
+ },
+ "button": {
+ "export": "Извоз",
+ "markAsReviewed": "Означити као прегледано",
+ "markAsUnreviewed": "Означити као непрегледано",
+ "deleteNow": "Обрисати сада"
+ }
+ },
+ "imagePicker": {
+ "selectImage": "Избор сличице за праћени објекат"
}
}
diff --git a/web/public/locales/sr/components/filter.json b/web/public/locales/sr/components/filter.json
index e00ac754d..21c799104 100644
--- a/web/public/locales/sr/components/filter.json
+++ b/web/public/locales/sr/components/filter.json
@@ -1,7 +1,7 @@
{
"filter": "Filter",
"labels": {
- "label": "Labele",
+ "label": "Ознаке",
"all": {
"title": "Sve oznake",
"short": "Oznake"
@@ -10,6 +10,131 @@
"count_other": "{{count}} Oznake"
},
"zones": {
- "label": "Zone"
+ "label": "Zone",
+ "all": {
+ "title": "Sve zone",
+ "short": "Zone"
+ }
+ },
+ "classes": {
+ "label": "Класе",
+ "all": {
+ "title": "Све класе"
+ },
+ "count_one": "{{count}} класа",
+ "count_other": "{{count}} класа"
+ },
+ "dates": {
+ "selectPreset": "Изаберите предефинисано…",
+ "all": {
+ "title": "Сви датуми",
+ "short": "Датуми"
+ }
+ },
+ "more": "Још филтера",
+ "reset": {
+ "label": "Ресетовање филтера на подразумеване вредности"
+ },
+ "timeRange": "Распон времена",
+ "subLabels": {
+ "label": "Под-ознаке",
+ "all": "Све под-ознаке"
+ },
+ "attributes": {
+ "label": "Атрибути класификације",
+ "all": "Сви атрибути"
+ },
+ "score": "Резултат",
+ "estimatedSpeed": "Процењена брзина ({{unit}})",
+ "features": {
+ "label": "Особине",
+ "hasSnapshot": "Постоји снимак",
+ "hasVideoClip": "Постоји видео клип",
+ "submittedToFrigatePlus": {
+ "label": "Послато у Frigate+",
+ "tips": "Прво морате филтрирати праћене објекте који имају снимак.
Праћени објекти без снимка не могу бити послати у Frigate+."
+ }
+ },
+ "sort": {
+ "label": "Сортирање",
+ "dateAsc": "Датум (растући)",
+ "dateDesc": "Дату (опадајући)",
+ "scoreAsc": "Резултат објекта (растући)",
+ "scoreDesc": "Резултат објекта (опадајући)",
+ "speedAsc": "Процењена брзина (растућа)",
+ "speedDesc": "Процењена брзина (опадајућа)",
+ "relevance": "Значај"
+ },
+ "cameras": {
+ "label": "Филтери камера",
+ "all": {
+ "title": "Све камере",
+ "short": "Камере"
+ }
+ },
+ "review": {
+ "showReviewed": "Прикажи прегледане"
+ },
+ "motion": {
+ "showMotionOnly": "Прикажи само покрете"
+ },
+ "explore": {
+ "settings": {
+ "title": "Подешавања",
+ "defaultView": {
+ "title": "Подразумевани приказ",
+ "desc": "Када нису изабрани филтери приказати сажето најскорије праћене објекте по ознакама или приказати нефилтрирану табелу.",
+ "summary": "Сумарно",
+ "unfilteredGrid": "Нефилтрирана табела"
+ },
+ "gridColumns": {
+ "title": "Колоне табеле",
+ "desc": "Изаберите број колона табеле које ће се приказати."
+ },
+ "searchSource": {
+ "label": "Извор претраге",
+ "desc": "Изаберите да ли да се претражују сличице или описи праћених објеката.",
+ "options": {
+ "thumbnailImage": "Сличица",
+ "description": "Опис"
+ }
+ }
+ },
+ "date": {
+ "selectDateBy": {
+ "label": "Изаберите датум по ком ће се филтрирати"
+ }
+ }
+ },
+ "logSettings": {
+ "label": "Ниво логовања филтера",
+ "filterBySeverity": "Филтрирање логова по озбиљности",
+ "loading": {
+ "title": "Учитавање",
+ "desc": "Када се лог панел скролује до дна, нови записи се аутоматски приказују чим су додати."
+ },
+ "disableLogStreaming": "Искључивање ажурирања лога",
+ "allLogs": "Сви логови"
+ },
+ "trackedObjectDelete": {
+ "title": "Потврдите брисање",
+ "desc": "Брисање ових {{objectLength}} праћених објеката уклања снимке, све сачуване ембединге, као и све повезанезаписе везане за животни циклус објекта. Снимци праћених објеката у Историји НЕЋЕ бити избрисани.
Да ли сте сигурни да желите да наставите?
Држите притиснут Shift тастер да прескочите овај дијалог у будућности.",
+ "toast": {
+ "success": "Праћени објекти су успешно обрисани.",
+ "error": "Брисање праћених објеката није успело: {{errorMessage}}"
+ }
+ },
+ "zoneMask": {
+ "filterBy": "Филтрирање по маскама зоне"
+ },
+ "recognizedLicensePlates": {
+ "title": "Препознате регистарске таблице",
+ "loadFailed": "Учитавање препознатих регистарских таблица није успело.",
+ "loading": "Учитавање препознатих регистарских таблица…",
+ "placeholder": "Претражите регистарске таблице…",
+ "noLicensePlatesFound": "Регистарске таблице нису пронађене.",
+ "selectPlatesFromList": "Изаберите једне или више таблица са листе.",
+ "selectAll": "Изаберите све",
+ "clearAll": "Почистите све"
}
}
diff --git a/web/public/locales/sr/components/player.json b/web/public/locales/sr/components/player.json
index e827547d8..afe54020d 100644
--- a/web/public/locales/sr/components/player.json
+++ b/web/public/locales/sr/components/player.json
@@ -8,6 +8,44 @@
},
"livePlayerRequiredIOSVersion": "Za ovaj tip prenosa uživo potreban je iOS 17.1 ili noviji.",
"streamOffline": {
- "title": "Strim je oflajn"
+ "title": "Strim je oflajn",
+ "desc": "Ни један фрејм није добијен од {{cameraName}} detect, проверите лог грешака"
+ },
+ "cameraDisabled": "Камера је онемогућена",
+ "stats": {
+ "streamType": {
+ "title": "Тип стрима:",
+ "short": "Тип"
+ },
+ "bandwidth": {
+ "title": "Пропусни опсег:",
+ "short": "Ширина опсега"
+ },
+ "latency": {
+ "title": "Кашњење:",
+ "value": "{{seconds}} секунди",
+ "short": {
+ "title": "Кашњење",
+ "value": "{{seconds}}s"
+ }
+ },
+ "totalFrames": "Укупно фрејмова:",
+ "droppedFrames": {
+ "title": "Изгубљени фрејмови:",
+ "short": {
+ "title": "Испуштено",
+ "value": "{{droppedFrames}} фрејмова"
+ }
+ },
+ "decodedFrames": "Декодовани фрејмови:",
+ "droppedFrameRate": "Однос испуштених фрејмова:"
+ },
+ "toast": {
+ "success": {
+ "submittedFrigatePlus": "Фрејм је успешно послат у Фригејт+"
+ },
+ "error": {
+ "submitFrigatePlusFailed": "Неуспешно слање фрејма у Фригејт+"
+ }
}
}
diff --git a/web/public/locales/sr/objects.json b/web/public/locales/sr/objects.json
index 75f353ded..e6683036a 100644
--- a/web/public/locales/sr/objects.json
+++ b/web/public/locales/sr/objects.json
@@ -5,5 +5,50 @@
"motorcycle": "Motor",
"airplane": "Avion",
"bus": "Autobus",
- "train": "Voz"
+ "train": "Voz",
+ "boat": "Brod",
+ "traffic_light": "Семафор",
+ "fire_hydrant": "Хидрант",
+ "street_sign": "Улични знак",
+ "stop_sign": "Знак стоп",
+ "parking_meter": "Паркинг апарат",
+ "bench": "Клупа",
+ "bird": "Птица",
+ "cat": "Мачка",
+ "dog": "Пас",
+ "horse": "Коњ",
+ "sheep": "Овца",
+ "cow": "Крава",
+ "elephant": "Слон",
+ "bear": "Медвед",
+ "zebra": "Зебра",
+ "giraffe": "Жирафа",
+ "hat": "Капа",
+ "backpack": "Ранац",
+ "umbrella": "Кишобран",
+ "shoe": "Ципела",
+ "eye_glasses": "Наочаре",
+ "handbag": "Ручна торба",
+ "tie": "Кравата",
+ "suitcase": "Актовка",
+ "frisbee": "Фризби",
+ "skis": "Скије",
+ "snowboard": "Сноуборд",
+ "sports_ball": "Спортска лопта",
+ "baseball_bat": "Палица за бејзбол",
+ "baseball_glove": "Рукавица за бејзбол",
+ "kite": "Змај",
+ "skateboard": "Скејтборд",
+ "surfboard": "Даска за сурфовање",
+ "tennis_racket": "Тениски рекет",
+ "bottle": "Боца",
+ "plate": "Тањир",
+ "wine_glass": "Чаша за вино",
+ "cup": "Шоља",
+ "fork": "Виљушка",
+ "knife": "Нож",
+ "spoon": "Кашика",
+ "bowl": "Посуда",
+ "banana": "Банана",
+ "apple": "Јабука"
}
diff --git a/web/public/locales/sr/views/classificationModel.json b/web/public/locales/sr/views/classificationModel.json
new file mode 100644
index 000000000..68abd5cbf
--- /dev/null
+++ b/web/public/locales/sr/views/classificationModel.json
@@ -0,0 +1,90 @@
+{
+ "documentTitle": "Класификациони модели - Фригејт",
+ "details": {
+ "scoreInfo": "Резултат представља просечно поверење у класификацију код свих откривања овог објекта.",
+ "none": "Ниједан",
+ "unknown": "Непознато"
+ },
+ "button": {
+ "deleteClassificationAttempts": "Брисање класификационих слика",
+ "renameCategory": "Преименовање класе",
+ "deleteCategory": "Брисање класе",
+ "deleteImages": "Брисање слика",
+ "trainModel": "Модел за тренирање",
+ "addClassification": "Додавање класификације",
+ "deleteModels": "Брисање модела",
+ "editModel": "Уређивање модела"
+ },
+ "tooltip": {
+ "trainingInProgress": "Модел се тренутно тренира",
+ "noNewImages": "Нема нових слика за тренирање. Класификујте више слика прво у датасету.",
+ "noChanges": "Нема измена у датасету од последњег тренирања.",
+ "modelNotReady": "Модел није спреман за тренирање"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Обрисана класа",
+ "deletedImage": "Обрисане слике",
+ "deletedModel_one": "Успешно је обрисан {{count}} модел",
+ "deletedModel_few": "Успешно су обрисана {{count}} модела",
+ "deletedModel_other": "Успешно је обрисано {{count}} модела",
+ "categorizedImage": "Успешно класификована слика",
+ "trainedModel": "Успешно трениран модел.",
+ "trainingModel": "Тренирање модела је успешно започето.",
+ "updatedModel": "Успешно је ажурирана конфигурација модела",
+ "renamedCategory": "Класа је успешно преименована у {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Неуспешно брисање: {{errorMessage}}",
+ "deleteCategoryFailed": "Неуспешно брисање класе: {{errorMessage}}",
+ "deleteModelFailed": "Неуспешно брисање модела: {{errorMessage}}",
+ "categorizeFailed": "Неуспешна категоризација слике: {{errorMessage}}",
+ "trainingFailed": "Неуспешно тренирање модела. Проверите Фригејт логове за детаље.",
+ "trainingFailedToStart": "Неуспешан почетак тренирања модела: {{errorMessage}}",
+ "updateModelFailed": "Неуспешно ажурирање модела: {{errorMessage}}",
+ "renameCategoryFailed": "Неуспешно преименовање класе: {{errorMessage}}"
+ }
+ },
+ "train": {
+ "titleShort": "Скорашње",
+ "title": "Скорашње класификације"
+ },
+ "deleteCategory": {
+ "title": "Брисање класе",
+ "desc": "Да ли сте сигурни да желите да обришете класу {{name}}? Тиме ће трајно бити обрисане и све придружене слике и биће потребно поновно тренирање модела.",
+ "minClassesTitle": "Није могуће обрисати класу",
+ "minClassesDesc": "Класификациони модел мора имати најмање две класе. Додајте нову класу пре него што избришете ову."
+ },
+ "deleteModel": {
+ "title": "Брисање класификационог модела",
+ "single": "Да ли сте сигурни да желите да обришете {{name}}? Ово ће трајно обрисати све повезане податке, укључујући слике и податке за тренирање. Ова акција се не може накнадно опозвати.",
+ "desc_one": "Да ли сте сигурни да желите да обришете {{count}} модел? Ово ће трајно обрисати све повезане податке, укључујући и слике и податке за тренирање. Ова акција не може бити опозвана накнадно.",
+ "desc_few": "Да ли сте сигурни да желите да обришете {{count}} модела? Ово ће трајно обрисати све повезане податке, укључујући и слике и податке за тренирање. Ова акција не може бити опозвана накнадно.",
+ "desc_other": "Да ли сте сигурни да желите да обришете {{count}} модела? Ово ће трајно обрисати све повезане податке, укључујући и слике и податке за тренирање. Ова акција не може бити опозвана накнадно."
+ },
+ "edit": {
+ "title": "Уређивање класификационог модела",
+ "descriptionState": "Уређивање класа за класификациони модел овог стања. Измене ће захтевати поновно тренирање модела.",
+ "descriptionObject": "Уређивање типа објекта и типа касификације за овај објекат класификационог модела.",
+ "stateClassesInfo": "Напомена: Измена класа стања захтева поновно тренирање модела са ажурираним класама."
+ },
+ "deleteDatasetImages": {
+ "title": "Брисање слика датасета",
+ "desc_one": "Да ли сте сигурни да желите да обришете {{count}} слику из {{dataset}}? Ова акција се не може накнадно опозвати и захтева поновно тренирање модела.",
+ "desc_few": "Да ли сте сигурни да желите да обришете {{count}} слике из {{dataset}}? Ова акција се не може накнадно опозвати и захтева поновно тренирање модела.",
+ "desc_other": "Да ли сте сигурни да желите да обришете {{count}} слика из {{dataset}}? Ова акција се не може накнадно опозвати и захтева поновно тренирање модела."
+ },
+ "deleteTrainImages": {
+ "title": "Брисање слика за тренирање",
+ "desc_one": "Да ли сте сигурни да желите да избришете {{count}} слику? Ова акција не може бити накнадно опозвана.",
+ "desc_few": "Да ли сте сигурни да желите да избришете {{count}} слике? Ова акција не може бити накнадно опозвана.",
+ "desc_other": "Да ли сте сигурни да желите да избришете {{count}} слика? Ова акција не може бити накнадно опозвана."
+ },
+ "renameCategory": {
+ "title": "Преименовање класе",
+ "desc": "Унесите ново име за {{name}}. Мораћете поново да тренирате модел да би промена имала ефекта."
+ },
+ "description": {
+ "invalidName": "Неисправно име. Имена могу да садрже само слова, цифре, размаке, апострофе, доње црте и повлаке."
+ }
+}
diff --git a/web/public/locales/sr/views/configEditor.json b/web/public/locales/sr/views/configEditor.json
index a94a6e5bd..18fba5a28 100644
--- a/web/public/locales/sr/views/configEditor.json
+++ b/web/public/locales/sr/views/configEditor.json
@@ -8,6 +8,11 @@
"toast": {
"success": {
"copyToClipboard": "Konfiguracija je kopirana u clipboard."
+ },
+ "error": {
+ "savingError": "Грешка при чувању конфигурације"
}
- }
+ },
+ "safeConfigEditor": "Уређивач конфигурације (безбедан режим)",
+ "safeModeDescription": "Фригејт је у безбедном режиму због грешке при провери исправности конфигурације."
}
diff --git a/web/public/locales/sr/views/events.json b/web/public/locales/sr/views/events.json
index 8a1b76e45..a07288b29 100644
--- a/web/public/locales/sr/views/events.json
+++ b/web/public/locales/sr/views/events.json
@@ -8,6 +8,58 @@
"allCameras": "Sve Kamere",
"empty": {
"alert": "Nema upozorenja za pregled",
- "detection": "Nema detekcija za pregled"
- }
+ "detection": "Nema detekcija za pregled",
+ "motion": "Nema podataka o pokretu",
+ "recordingsDisabled": {
+ "title": "Снимање мора бити омогућено",
+ "description": "Преглед ставки може бити креиран само за камеру када је омогућено снимање за њу."
+ }
+ },
+ "timeline": "Временска линија",
+ "timeline.aria": "Изаберите временску линију",
+ "zoomIn": "Зумирање",
+ "zoomOut": "Одзумирање",
+ "events": {
+ "label": "Догађаји",
+ "aria": "Изаберите догађаје",
+ "noFoundForTimePeriod": "Нису пронађени догађају у овом периоду."
+ },
+ "detail": {
+ "label": "Детаљ",
+ "noDataFound": "Нема детаљних података за преглед",
+ "aria": "Промена детаљности прегледа",
+ "trackedObject_one": "{{count}} објеката",
+ "trackedObject_other": "{{count}} објеката",
+ "noObjectDetailData": "Нема података о детаљима објекта.",
+ "settings": "Подешавање приказа детаља",
+ "alwaysExpandActive": {
+ "title": "Увек проширити активан",
+ "desc": "Увек прошири детаље кативног прегледа објекта, уколико су доступни."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Праћена тачка",
+ "clickToSeek": "Кликните да претражите у ово време"
+ },
+ "documentTitle": "Преглед - Фригејт",
+ "recordings": {
+ "documentTitle": "Снимци - Фригејт"
+ },
+ "calendarFilter": {
+ "last24Hours": "Последња 24 часа"
+ },
+ "markAsReviewed": "Означавање да је прегледано",
+ "markTheseItemsAsReviewed": "Означи ове ставке као прегледане",
+ "newReviewItems": {
+ "label": "Приказ нових ставки за прегледање",
+ "button": "Нове ставке за преглед"
+ },
+ "selected_one": "{{count}} изабрано",
+ "selected_other": "{{count}} изабрано",
+ "select_all": "Све",
+ "camera": "Камера",
+ "detected": "детектовано",
+ "normalActivity": "Нормално",
+ "needsReview": "Потребан је преглед",
+ "securityConcern": "Безбедносно питање"
}
diff --git a/web/public/locales/sr/views/explore.json b/web/public/locales/sr/views/explore.json
index 66e8fbffe..c79ae1fbe 100644
--- a/web/public/locales/sr/views/explore.json
+++ b/web/public/locales/sr/views/explore.json
@@ -7,7 +7,73 @@
"embeddingsReindexing": {
"context": "Istraživanje se može koristiti nakon što se završi reindeksiranje ugrađivanja praćenih objekata.",
"startingUp": "Pokretanje…",
- "estimatedTime": "Procenjeno preostalo vreme:"
+ "estimatedTime": "Procenjeno preostalo vreme:",
+ "finishingShortly": "Завршава се ускоро",
+ "step": {
+ "thumbnailsEmbedded": "Угњеждене сличице: ",
+ "descriptionsEmbedded": "Угњеждени описи: ",
+ "trackedObjectsProcessed": "Обрађени праћени објекти: "
+ }
+ },
+ "downloadingModels": {
+ "context": "Фригејт преузима неопходне embedding моделе за подршку могућности Семантичке претраге. Ово може потрајати неколико минута, зависно од брзине Ваше мрежне везе.",
+ "setup": {
+ "visionModel": "Модел визије",
+ "visionModelFeatureExtractor": "Екстрактор особина модела визије",
+ "textModel": "Модел текста",
+ "textTokenizer": "Токенизатор текста"
+ },
+ "tips": {
+ "context": "Можда ћете желети да реиндексујете ембединге праћених објеката када модели буду преузети."
+ },
+ "error": "Дошло је до грешке. Проверите логове."
+ }
+ },
+ "details": {
+ "timestamp": "Временски тренутак"
+ },
+ "trackedObjectDetails": "Детаљи праћеног објекта",
+ "type": {
+ "details": "детаљи",
+ "snapshot": "снимак",
+ "thumbnail": "сличица",
+ "video": "видео",
+ "tracking_details": "детаљи праћења"
+ },
+ "trackingDetails": {
+ "title": "Детаљи праћења",
+ "noImageFound": "Нема слике за овај временски тренутак.",
+ "createObjectMask": "Креирање маске објекта",
+ "adjustAnnotationSettings": "Прилагођавање подешавања анотације",
+ "scrollViewTips": "Кликните да видите значајне моменте у животном циклусу овог објекта.",
+ "autoTrackingTips": "Позиције оквира неће бити тачне за камере са аутоматским праћењем.",
+ "count": "{{first}} од {{second}}",
+ "trackedPoint": "Праћена тачка",
+ "lifecycleItemDesc": {
+ "visible": "{{label}} детектован",
+ "entered_zone": "{{label}} је ушао у {{zones}}",
+ "active": "{{label}} се активирао",
+ "stationary": "{{label}} је постао стационаран",
+ "attribute": {
+ "faceOrLicense_plate": "{{attribute}} детектован за {{label}}",
+ "other": "{{label}} је препознат као {{attribute}}"
+ },
+ "gone": "{{label}} преостало",
+ "heard": "{{label}} се чуло",
+ "external": "{{label}} детектован",
+ "header": {
+ "zones": "Зоне",
+ "ratio": "Однос",
+ "area": "Подручје",
+ "score": "Резултат"
+ }
+ },
+ "annotationSettings": {
+ "title": "Подешавања анотације",
+ "showAllZones": {
+ "title": "Приказ свих зона",
+ "desc": "Увек приказати зоне на фрејмовима у којима су објекти ушли у зону."
+ }
}
}
}
diff --git a/web/public/locales/sr/views/exports.json b/web/public/locales/sr/views/exports.json
index a12e06163..2f5acb766 100644
--- a/web/public/locales/sr/views/exports.json
+++ b/web/public/locales/sr/views/exports.json
@@ -6,6 +6,18 @@
"deleteExport.desc": "Da li zaista želite obrisati {{exportName}}?",
"editExport": {
"title": "Preimenuj izvoz",
- "desc": "Unesite novo ime za ovaj izvoz."
+ "desc": "Unesite novo ime za ovaj izvoz.",
+ "saveExport": "Sačuvaj izvoz"
+ },
+ "tooltip": {
+ "shareExport": "Дељење експорта",
+ "downloadVideo": "Преузимање видео-снимка",
+ "editName": "Уређивање имена",
+ "deleteExport": "Брисање извоза"
+ },
+ "toast": {
+ "error": {
+ "renameExportFailed": "Промена назива извоза није успела: {{errorMessage}}"
+ }
}
}
diff --git a/web/public/locales/sr/views/faceLibrary.json b/web/public/locales/sr/views/faceLibrary.json
index 766a52aa9..cb9068656 100644
--- a/web/public/locales/sr/views/faceLibrary.json
+++ b/web/public/locales/sr/views/faceLibrary.json
@@ -1,12 +1,96 @@
{
"description": {
- "addFace": "Prođite kroz dodavanje nove kolekcije u biblioteku lica.",
+ "addFace": "Додавање нове колекције у библиотеку лица отпремањем прве слике.",
"placeholder": "Unesite ime za ovu kolekciju",
- "invalidName": "Nevažeće ime. Imena mogu da sadrže samo slova, brojeve, razmake, apostrofe, donje crte i crtice."
+ "invalidName": "Неисправно име. Имена могу да садрже само слова, цифре, размаке, апострофе, доње црте и повлаке."
},
"details": {
"person": "Osoba",
"subLabelScore": "Sub Label Skor",
- "scoreInfo": "Rezultat podoznake je otežan rezultat za sve prepoznate pouzdanosti lica, tako da se može razlikovati od rezultata prikazanog na snimku."
+ "scoreInfo": "Rezultat podoznake je otežan rezultat za sve prepoznate pouzdanosti lica, tako da se može razlikovati od rezultata prikazanog na snimku.",
+ "face": "Detalji lica",
+ "faceDesc": "Detalji praćenog objekta koji je generisao ovo lice",
+ "timestamp": "Временски тренутак",
+ "unknown": "Непознато"
+ },
+ "documentTitle": "Библиотека лица - Фригејт",
+ "uploadFaceImage": {
+ "title": "Отпремање слике лица",
+ "desc": "Орпремање слике за скенирање за лица и укључивање у {{pageToggle}}"
+ },
+ "collections": "Колекције",
+ "createFaceLibrary": {
+ "new": "Креирање новог лика",
+ "nextSteps": "За изградњу снажне основе: Користите картицу \"Скорашња препознавања\" да бисте изабрали и тренирали на сликама за сваку од откривених особа. За најбоље резултате фокусирајте се на фронталне слике; избегавајте тренирање на сликама где су лица приказана под углом. "
+ },
+ "steps": {
+ "faceName": "Унесите назив лица",
+ "uploadFace": "Отпремање слике лица",
+ "nextSteps": "Следећи кораци",
+ "description": {
+ "uploadFace": "Отпремите слику {{name}} која приказује његово/њено лице спреда. Слика не мора да садржи само лице."
+ }
+ },
+ "train": {
+ "title": "Скорашња препознавања",
+ "titleShort": "Скорашње",
+ "aria": "Изаберите скорашња препознавања",
+ "empty": "Нема скорашњих покушаја препознавања лица"
+ },
+ "deleteFaceLibrary": {
+ "title": "Брисање имена",
+ "desc": "Да ли сте сигурни да желите да обришете колекцију {{name}}? То ће трајно обрисати и сва придружена лица."
+ },
+ "deleteFaceAttempts": {
+ "title": "Обрисана лица",
+ "desc_one": "Да ли сте сигурни да желите да обришете {{count}} лице? Ова акција се не може опозвати накнадно.",
+ "desc_few": "Да ли сте сигурни да желите да обришете {{count}} лица? Ова акција се не може опозвати накнадно.",
+ "desc_other": "Да ли сте сигурни да желите да обришете {{count}} лица? Ова акција се не може опозвати накнадно."
+ },
+ "renameFace": {
+ "title": "Преименовање лица",
+ "desc": "Унесите ново име за {{name}}"
+ },
+ "button": {
+ "deleteFaceAttempts": "Брисање лица",
+ "addFace": "Додавање лица",
+ "renameFace": "Преименовање лица",
+ "deleteFace": "Брисање лица",
+ "uploadImage": "Отпремање слике",
+ "reprocessFace": "Поново обради лице"
+ },
+ "imageEntry": {
+ "validation": {
+ "selectImage": "Изаберите фајл са сликом."
+ },
+ "dropActive": "Превуците слику овде…",
+ "dropInstructions": "Превуците или пејстујте слику овде, или кликните за избор",
+ "maxSize": "Максимална величина: {{size}}MB"
+ },
+ "nofaces": "Нема доступних лица",
+ "trainFaceAs": "Тренирање лица као:",
+ "trainFace": "Тренирање лица",
+ "toast": {
+ "success": {
+ "uploadedImage": "Слика је успешно отпремљена.",
+ "addFaceLibrary": "{{name}} је успешно додат у библиотеку лица!",
+ "deletedFace_one": "Успешно је обрисано {{count}} лице.",
+ "deletedFace_few": "Успешно је обрисано {{count}} лица.",
+ "deletedFace_other": "Успешно је обрисано {{count}} лица.",
+ "deletedName_one": "{{count}} лице је успешно обрисано.",
+ "deletedName_few": "{{count}} лица су успешно обрисана.",
+ "deletedName_other": "{{count}} лица је успешно обрисано.",
+ "renamedFace": "Лице је успешно преименовано у {{name}}",
+ "trainedFace": "Лице је успешно истренирано.",
+ "updatedFaceScore": "Успешно је ажуриран резултат лица за {{name}} ({{score}})."
+ },
+ "error": {
+ "uploadingImageFailed": "Неуспешно отпремање слике: {{errorMessage}}",
+ "addFaceLibraryFailed": "Неуспешно постављање имена лица: {{errorMessage}}",
+ "deleteFaceFailed": "Неуспешно брисање: {{errorMessage}}",
+ "deleteNameFailed": "Неуспешно брисање имена: {{errorMessage}}",
+ "renameFaceFailed": "Неуспешна промена назива лица: {{errorMessage}}",
+ "trainFailed": "Неуспешно тренирање: {{errorMessage}}"
+ }
}
}
diff --git a/web/public/locales/sr/views/live.json b/web/public/locales/sr/views/live.json
index fe19046a3..3364e7cdc 100644
--- a/web/public/locales/sr/views/live.json
+++ b/web/public/locales/sr/views/live.json
@@ -7,6 +7,107 @@
"disable": "Onemogućite dvosmerni razgovor"
},
"cameraAudio": {
- "enable": "Omogući zvuk kamere"
+ "enable": "Omogući zvuk kamere",
+ "disable": "Onemogući zvuk kamere"
+ },
+ "ptz": {
+ "move": {
+ "clickMove": {
+ "label": "Kliknite na sliku da bi centrirali kameru",
+ "enable": "Укључивање померања кликом",
+ "disable": "Онемогућавање померања кликом"
+ },
+ "left": {
+ "label": "Померање PTZ камере у лево"
+ },
+ "up": {
+ "label": "Окретање PTZ камере на горе"
+ },
+ "down": {
+ "label": "Окретање PTZ камере на доле"
+ },
+ "right": {
+ "label": "Окретање PTZ камере у десно"
+ }
+ },
+ "zoom": {
+ "in": {
+ "label": "Зумирање PTZ камере"
+ },
+ "out": {
+ "label": "Одзумирање PTZ камере"
+ }
+ },
+ "focus": {
+ "in": {
+ "label": "Фокусирање PTZ камере"
+ },
+ "out": {
+ "label": "Одфокусирање PTZ камере"
+ }
+ },
+ "frame": {
+ "center": {
+ "label": "Кликните унутар фрејма да центрирате PTZ камеру"
+ }
+ },
+ "presets": "Пресети PTZ камере"
+ },
+ "camera": {
+ "enable": "Укључивање камере",
+ "disable": "Онемогућавање камере"
+ },
+ "muteCameras": {
+ "enable": "Мутирање свих камера",
+ "disable": "Демутирање свих камера"
+ },
+ "detect": {
+ "enable": "Укључивање детекције",
+ "disable": "Искључивање детекције"
+ },
+ "recording": {
+ "enable": "Укључивање снимања",
+ "disable": "Искључивање снимања"
+ },
+ "snapshots": {
+ "enable": "Укључивање снепшотова",
+ "disable": "Онемогућивање снепшотова"
+ },
+ "snapshot": {
+ "takeSnapshot": "Преузимање тренутног снимка",
+ "noVideoSource": "Нема доступних извора за снепшот.",
+ "captureFailed": "Неуспешно прављење снепшота.",
+ "downloadStarted": "Преузимање снепшота је започето."
+ },
+ "audioDetect": {
+ "enable": "Омогућавање детектовања звука",
+ "disable": "Онемогућавање детекције звука"
+ },
+ "transcription": {
+ "enable": "Омогућавање транскрибовања звука уживо",
+ "disable": "Искључивање транскрибовања звука уживо"
+ },
+ "autotracking": {
+ "enable": "Омогућавање аутоматског праћења",
+ "disable": "Онемогућити аутоматско праћење"
+ },
+ "streamStats": {
+ "enable": "Приказ статистике стримовања",
+ "disable": "Скривање статистике стримовања"
+ },
+ "manualRecording": {
+ "title": "На захтев",
+ "tips": "Преузимање тренутног снепшота или ручно покретање догађаја засновано на подешавањима задржавања снимања ове камере.",
+ "playInBackground": {
+ "label": "Пустити у позадини",
+ "desc": "Укључите ову опцију да наставите стримовање када је плејер скривен."
+ },
+ "showStats": {
+ "label": "Приказ статистике"
+ },
+ "debugView": "Приказ за дебаговање",
+ "start": "Почетак снимања на захтев",
+ "started": "Ручно снимање на захтев је започето.",
+ "failedToStart": "Неуспешно покретање ручног снимања на захтев."
}
}
diff --git a/web/public/locales/sr/views/search.json b/web/public/locales/sr/views/search.json
index 3ab007f60..0c65ef36e 100644
--- a/web/public/locales/sr/views/search.json
+++ b/web/public/locales/sr/views/search.json
@@ -4,7 +4,70 @@
"searchFor": "Pretraži {{inputValue}}",
"button": {
"clear": "Obriši pretragu",
- "save": "Sačuvaj pretragu",
- "delete": "Izbrišite sačuvanu pretragu"
+ "save": "Чување претраге",
+ "delete": "Izbrišite sačuvanu pretragu",
+ "filterInformation": "Filtriraj informacije",
+ "filterActive": "Aktivni filteri"
+ },
+ "trackedObjectId": "ID праћеног објекта",
+ "filter": {
+ "label": {
+ "cameras": "Камере",
+ "labels": "Ознаке",
+ "zones": "Зоне",
+ "sub_labels": "Под-ознаке",
+ "attributes": "Атрибути",
+ "search_type": "Тип претраге",
+ "time_range": "Временски распон",
+ "before": "Пре",
+ "after": "Након",
+ "min_score": "Најнижи резултат",
+ "max_score": "Најбољи резултат",
+ "min_speed": "Најнижа брзина",
+ "max_speed": "Највиша брзина",
+ "recognized_license_plate": "Препознате регистарске таблице",
+ "has_clip": "Има клип",
+ "has_snapshot": "Има снепшот"
+ },
+ "searchType": {
+ "thumbnail": "Сличица",
+ "description": "Опис"
+ },
+ "toast": {
+ "error": {
+ "beforeDateBeLaterAfter": "Датум 'пре' мора бити након датума 'после'.",
+ "afterDatebeEarlierBefore": "Датум 'после' мора бити пре датума 'пре'.",
+ "minScoreMustBeLessOrEqualMaxScore": "'min_score' мора бити нижи или један 'max_score'.",
+ "maxScoreMustBeGreaterOrEqualMinScore": "'max_score' мора бити већи или једнак од 'min_score'.",
+ "minSpeedMustBeLessOrEqualMaxSpeed": "'min_speed' мора бити мања или једнака 'max_speed'.",
+ "maxSpeedMustBeGreaterOrEqualMinSpeed": "'max_speed' мора бити већа или једнака 'min_speed'."
+ }
+ },
+ "tips": {
+ "title": "Како да се користе филтери за текст",
+ "desc": {
+ "text": "Филтери Вам помажу да сузите резултате претраге. Ево како да их користите у пољима за унос:",
+ "step1": "Откуцајте назив кључа филтера а затим две тачке (нпр. \"cameras:\").",
+ "step2": "Изаберите предложену или сопствену вредност.",
+ "step3": "Примените више филтера тако што ћете их додати један за другим са размаком између.",
+ "step4": "Филтери за датум (пре: и касније:) користе {{DateFormat}} формат.",
+ "step5": "Филтер за временски распон користи {{exampleTime}} формат.",
+ "step6": "Уклоните филтере кликом на 'x' поред њих.",
+ "exampleLabel": "Пример:"
+ }
+ },
+ "header": {
+ "currentFilterType": "Филтрирање вредности",
+ "noFilters": "Филтери",
+ "activeFilters": "Активни филтери"
+ }
+ },
+ "similaritySearch": {
+ "title": "Претрага сличности",
+ "active": "Претрага по сличности је активна",
+ "clear": "Почистити претрагу сличности"
+ },
+ "placeholder": {
+ "search": "Претрага…"
}
}
diff --git a/web/public/locales/sr/views/settings.json b/web/public/locales/sr/views/settings.json
index 07a4ea59d..d3c55e664 100644
--- a/web/public/locales/sr/views/settings.json
+++ b/web/public/locales/sr/views/settings.json
@@ -5,6 +5,83 @@
"camera": "Podešavanje kamera - Frigate",
"enrichments": "Podešavanja obogaćivanja - Frigate",
"masksAndZones": "Uređivač maski i zona - Frigate",
- "motionTuner": "Tjuner pokreta - Frigate"
+ "motionTuner": "Tjuner pokreta - Frigate",
+ "general": "Подењавања UI - Фригејт",
+ "cameraManagement": "Управљање камерама - Фригејт",
+ "cameraReview": "Преглед подешавања камере - Фригејт",
+ "object": "Дебаговање - Фригејт",
+ "frigatePlus": "Подешавања за Фригејт+ - Фригејт",
+ "notifications": "Подешавања обавештавања - Фригејт"
+ },
+ "menu": {
+ "ui": "UI",
+ "enrichments": "Обогаћивања",
+ "cameraManagement": "Управљање",
+ "cameraReview": "Преглед",
+ "masksAndZones": "Маске / Зоне",
+ "motionTuner": "Подешавач покрета",
+ "triggers": "Окидачи",
+ "debug": "Дебаговање",
+ "users": "Корисници",
+ "roles": "Улоге",
+ "notifications": "Нотификације",
+ "frigateplus": "Фригејт+"
+ },
+ "dialog": {
+ "unsavedChanges": {
+ "title": "Имате несачуване измене.",
+ "desc": "Да ли желите да сачувате измене пре наставка?"
+ }
+ },
+ "cameraSetting": {
+ "camera": "Камера",
+ "noCamera": "Нема камере"
+ },
+ "general": {
+ "title": "UI подешавања",
+ "liveDashboard": {
+ "title": "Контролна табла уживо",
+ "automaticLiveView": {
+ "label": "Аутоматси преглед уживо",
+ "desc": "Аутоматско пребацивање на преглед камере уживо када је активност детектована. Онемогућавање ове опције доводи до тога да се слике камере на контролној тапли ажурирају једном у минуту."
+ },
+ "playAlertVideos": {
+ "label": "Репродукуј видео за узбуну",
+ "desc": "Скорашњa упозорења се на контролној табли подразумевано репродукују као мали видеи који се понављају. Онемогућите ову опцију за приказивање само статичке слике скорашњих упозорења (на овом уређају/браузеру)."
+ },
+ "displayCameraNames": {
+ "label": "Увек приказивати називе камера",
+ "desc": "Увек приказивати називе камера у чипу у репродукцији уживо више камера на контролној табли."
+ },
+ "liveFallbackTimeout": {
+ "desc": "Када стрим високог квалитета није доступан за камеру, спусти се на режим споре мреже након оволико секунди. Подразумевано 3."
+ }
+ },
+ "storedLayouts": {
+ "title": "Сачувани распореди",
+ "desc": "Распоред камера у групи може бити превлачен и може му се променити величина. Позиције су складиштене у локалном Веб браузеру.",
+ "clearAll": "Чишћење свих распореда"
+ },
+ "cameraGroupStreaming": {
+ "title": "Подешавање стримовања за групу камера",
+ "desc": "Подешавања стримовања за сваку групу камера чувају се у локалном браузеру.",
+ "clearAll": "Чишћење свих подешавања стримовања"
+ },
+ "recordingsViewer": {
+ "title": "Преглед снимака",
+ "defaultPlaybackRate": {
+ "label": "Подразумевана брзина репродукције",
+ "desc": "Подразумевана брзина репродукције за снимке."
+ }
+ },
+ "calendar": {
+ "title": "Календар",
+ "firstWeekday": {
+ "label": "Први дан у недељи",
+ "desc": "Дан којим недеље у календару прегледа почињу.",
+ "sunday": "Недеља",
+ "monday": "Понедељак"
+ }
+ }
}
}
diff --git a/web/public/locales/sr/views/system.json b/web/public/locales/sr/views/system.json
index 07f260401..436c9da6f 100644
--- a/web/public/locales/sr/views/system.json
+++ b/web/public/locales/sr/views/system.json
@@ -2,11 +2,91 @@
"documentTitle": {
"cameras": "Statusi kamera - Frigate",
"storage": "Statistika skladištenja - Frigate",
- "general": "Opšta statistika - Frigate",
+ "general": "Општа статистика - Фригејт",
"enrichments": "Statistika obogaćivanja - Frigate",
"logs": {
"frigate": "Frigate logovi - Frigate",
- "go2rtc": "Go2RTC dnevnici - Frigate"
+ "go2rtc": "Go2RTC dnevnici - Frigate",
+ "nginx": "Nginx logovi - Frigate"
+ }
+ },
+ "title": "Sistem",
+ "metrics": "Системске метрике",
+ "logs": {
+ "download": {
+ "label": "Преузимање логова"
+ },
+ "copy": {
+ "label": "Копирање",
+ "success": "Логови су копирани",
+ "error": "Копирање логова није успело"
+ },
+ "type": {
+ "label": "Тип",
+ "timestamp": "Временски тренутак",
+ "tag": "Ознака",
+ "message": "Порука"
+ },
+ "tips": "Логови стримују са сервера",
+ "toast": {
+ "error": {
+ "fetchingLogsFailed": "Грешка при преузимању логова: {{errorMessage}}",
+ "whileStreamingLogs": "Грешка код стримовања логова: {{errorMessage}}"
+ }
+ }
+ },
+ "general": {
+ "title": "Опште",
+ "detector": {
+ "title": "Детектори",
+ "inferenceSpeed": "Детектор брзине закључивања",
+ "temperature": "Детектор температуре",
+ "cpuUsage": "Детектор употребе CPU-а",
+ "cpuUsageInformation": "CPU коришћен за припрему улаза и излаза података у/из модела детекције. Ова вредност не мери коришћење инференције, чак ни када користи GPU или акселератор.",
+ "memoryUsage": "Употреба меморије од стране детектора"
+ },
+ "hardwareInfo": {
+ "title": "Информације о хардверу",
+ "gpuUsage": "Употреба GPU",
+ "gpuMemory": "GPU меморија",
+ "gpuEncoder": "GPU енкодер",
+ "gpuDecoder": "GPU декодер",
+ "gpuInfo": {
+ "vainfoOutput": {
+ "title": "Vainfo Output",
+ "returnCode": "Повратни код: {{code}}",
+ "processOutput": "Обрада излаза:",
+ "processError": "Грешка у обради:"
+ },
+ "nvidiaSMIOutput": {
+ "title": "Nvidia SMI излаз",
+ "name": "Назив: {{name}}",
+ "driver": "Драјвер: {{driver}}",
+ "cudaComputerCapability": "Способност CUDA рачунања: {{cuda_compute}}",
+ "vbios": "VBios Info: {{vbios}}"
+ },
+ "closeInfo": {
+ "label": "Затварање GPU информација"
+ },
+ "copyInfo": {
+ "label": "Копирање GPU ифнормација"
+ },
+ "toast": {
+ "success": "Копиране су GPU информације у клипборд"
+ }
+ },
+ "npuUsage": "Употреба NPU",
+ "npuMemory": "NPU меморија",
+ "intelGpuWarning": {
+ "title": "Упозорење за Intel GPU статистику",
+ "message": "GPU статистика није доступна",
+ "description": "Ово је познати баг у алатима за извештавање статистике код Intel GPU (intel_gpu_top) где се јавља пуцање и враћа 0% као GPU искоришћење, чак и у случајевима када хардверска акцелерација и детектовање објекта регуларно раде на (i)GPU. Ово није баг у Фригејту. Можете рестартовати хост да привремено поправите проблем и потврдите да GPU ради исправно. Ово не утиче на перформансе."
+ }
+ },
+ "otherProcesses": {
+ "title": "Остали процеси",
+ "processCpuUsage": "Процесна употреба CPU",
+ "processMemoryUsage": "Процесна употреба меморије"
}
}
}
diff --git a/web/public/locales/sv/audio.json b/web/public/locales/sv/audio.json
index 2e685096c..2de942a50 100644
--- a/web/public/locales/sv/audio.json
+++ b/web/public/locales/sv/audio.json
@@ -3,7 +3,7 @@
"bicycle": "Cykel",
"speech": "Tal",
"car": "Bil",
- "bellow": "Under",
+ "bellow": "Vrål",
"motorcycle": "Motorcykel",
"whispering": "Viskning",
"bus": "Buss",
@@ -150,7 +150,7 @@
"vehicle": "Fordon",
"skateboard": "Skatebord",
"door": "Dörr",
- "blender": "Mixer",
+ "blender": "Blandare",
"sink": "Vask",
"hair_dryer": "Hårfön",
"toothbrush": "Tandborste",
@@ -158,5 +158,346 @@
"strum": "Anslag",
"zither": "Citer",
"ukulele": "Ukulele",
- "piano": "Piano"
+ "piano": "Piano",
+ "electric_piano": "Elpiano",
+ "organ": "Orgel",
+ "electronic_organ": "Elektronisk orgel",
+ "hammond_organ": "Hammondorgel",
+ "synthesizer": "Synthesizer",
+ "sampler": "Provtagare",
+ "harpsichord": "Cembalo",
+ "percussion": "Slagverk",
+ "drum_kit": "Trumset",
+ "drum_machine": "Trummaskin",
+ "drum": "Trumma",
+ "french_horn": "Franskt horn",
+ "trumpet": "Trumpet",
+ "flute": "Flöjt",
+ "gong": "Gonggong",
+ "tubular_bells": "Rörklockor",
+ "mallet_percussion": "Malletinstrument",
+ "marimba": "Marimba",
+ "glockenspiel": "Klockspel",
+ "vibraphone": "Vibrafon",
+ "steelpan": "Stålpanna",
+ "orchestra": "Orkester",
+ "brass_instrument": "Bleckblåsinstrument",
+ "trombone": "Trombon",
+ "string_section": "Stråkinstrument",
+ "violin": "Fiol",
+ "pizzicato": "Pizzicato",
+ "cello": "Cello",
+ "double_bass": "Kontrabas",
+ "wind_instrument": "Blåsinstrument",
+ "saxophone": "Saxofon",
+ "clarinet": "Klarinett",
+ "harp": "Harpa",
+ "bell": "Klocka",
+ "church_bell": "Kyrkklocka",
+ "jingle_bell": "Bjällerklang",
+ "bicycle_bell": "Cykelklocka",
+ "tuning_fork": "Stämgaffel",
+ "chime": "Klämta",
+ "wind_chime": "Vindspel",
+ "harmonica": "Munspel",
+ "accordion": "Dragspel",
+ "bagpipes": "Säckpipor",
+ "didgeridoo": "Didjeridu",
+ "theremin": "Teremin",
+ "singing_bowl": "Sjungande skål",
+ "scratching": "Repa",
+ "pop_music": "Popmusik",
+ "hip_hop_music": "Hiphopmusik",
+ "beatboxing": "Beatboxning",
+ "rock_music": "Rockmusik",
+ "heavy_metal": "Heavy Metal musik",
+ "punk_rock": "Punkrock",
+ "grunge": "Grunge",
+ "progressive_rock": "Progressiv rock",
+ "rock_and_roll": "Rock and roll",
+ "psychedelic_rock": "Psykedelisk rock",
+ "rhythm_and_blues": "Rytm och blues",
+ "soul_music": "Soulmusik",
+ "reggae": "Reggae",
+ "country": "Land",
+ "swing_music": "Swingmusik",
+ "bluegrass": "Bluegrass",
+ "funk": "Funk",
+ "folk_music": "Folkmusik",
+ "middle_eastern_music": "Mellanösternmusik",
+ "jazz": "Jazz",
+ "disco": "Disko",
+ "classical_music": "Klassisk musik",
+ "opera": "Opera",
+ "electronic_music": "Elektronisk musik",
+ "house_music": "Housemusik",
+ "techno": "Tekno",
+ "dubstep": "Dubstep",
+ "drum_and_bass": "Trumma och bas",
+ "electronica": "Elektronisk musik",
+ "electronic_dance_music": "Elektronisk dansmusik",
+ "ambient_music": "Ambientmusik",
+ "trance_music": "Trancemusik",
+ "music_of_latin_america": "Latinamerikansk musik",
+ "salsa_music": "Salsamusik",
+ "flamenco": "Flamenco",
+ "blues": "Blues",
+ "music_for_children": "Musik för barn",
+ "new-age_music": "New Age-musik",
+ "vocal_music": "Vokalmusik",
+ "a_capella": "A cappella",
+ "music_of_africa": "Afrikansk musik",
+ "afrobeat": "Afrobeat",
+ "christian_music": "Kristen musik",
+ "gospel_music": "Gospelmusik",
+ "music_of_asia": "Asiens musik",
+ "carnatic_music": "Karnatisk musik",
+ "music_of_bollywood": "Bollywoods musik",
+ "ska": "Ska",
+ "traditional_music": "Traditionell musik",
+ "independent_music": "Oberoende musik",
+ "song": "Låt",
+ "background_music": "Bakgrundsmusik",
+ "theme_music": "Temamusik",
+ "jingle": "Klingande",
+ "soundtrack_music": "Soundtrackmusik",
+ "lullaby": "Vaggvisa",
+ "video_game_music": "Videospelsmusik",
+ "christmas_music": "Julmusik",
+ "dance_music": "Dansmusik",
+ "wedding_music": "Bröllopsmusik",
+ "happy_music": "Glad musik",
+ "sad_music": "Sorglig musik",
+ "tender_music": "Öm musik",
+ "exciting_music": "Spännande musik",
+ "angry_music": "Arg musik",
+ "scary_music": "Skräckmusik",
+ "wind": "Vind",
+ "rustling_leaves": "Prasslande löv",
+ "wind_noise": "Vindbrus",
+ "thunderstorm": "Åskväder",
+ "thunder": "Åska",
+ "water": "Vatten",
+ "rain": "Regn",
+ "raindrop": "Regndroppe",
+ "rain_on_surface": "Regn på ytan",
+ "stream": "Strömma",
+ "waterfall": "Vattenfall",
+ "ocean": "Hav",
+ "waves": "Vågor",
+ "steam": "Ånga",
+ "gurgling": "Gurglande",
+ "fire": "Brand",
+ "crackle": "Spraka",
+ "sailboat": "Segelbåt",
+ "rowboat": "Roddbåt",
+ "motorboat": "Motorbåt",
+ "ship": "Fartyg",
+ "motor_vehicle": "Motorfordon",
+ "power_windows": "Elfönster",
+ "skidding": "Slirning",
+ "tire_squeal": "Däckskrik",
+ "toot": "Tuta",
+ "car_alarm": "Billarm",
+ "car_passing_by": "Bil som passerar",
+ "race_car": "Racerbil",
+ "truck": "Lastbil",
+ "air_brake": "Luftbroms",
+ "air_horn": "Lufthorn",
+ "reversing_beeps": "Backningljud",
+ "ice_cream_truck": "Glassbil",
+ "emergency_vehicle": "Akutbil",
+ "police_car": "Polisbil",
+ "ambulance": "Ambulans",
+ "fire_engine": "Brandbil",
+ "traffic_noise": "Trafikbuller",
+ "rail_transport": "Järnvägstransport",
+ "train_whistle": "Tågvissla",
+ "train_horn": "Tåghorn",
+ "railroad_car": "Järnvägsvagn",
+ "train_wheels_squealing": "Tåghjul skriker",
+ "subway": "Tunnelbana",
+ "aircraft": "Flygplan",
+ "aircraft_engine": "Flygmotor",
+ "jet_engine": "Jetmotor",
+ "propeller": "Propeller",
+ "helicopter": "Helikopter",
+ "fixed-wing_aircraft": "Flygplan med fasta vingar",
+ "engine": "Motor",
+ "light_engine": "Ljusmotor",
+ "lawn_mower": "Gräsklippare",
+ "chainsaw": "Motorsåg",
+ "doorbell": "Dörrklocka",
+ "electric_toothbrush": "Eltandborste",
+ "computer_keyboard": "Tangentbord",
+ "alarm": "Larm",
+ "telephone": "Telefon",
+ "ringtone": "Ringsignal",
+ "dial_tone": "Rington",
+ "busy_signal": "Upptagetsignal",
+ "alarm_clock": "Alarmklocka",
+ "smoke_detector": "Brandvarnare",
+ "fire_alarm": "Brandlarm",
+ "dental_drill's_drill": "Tandläkarborr",
+ "medium_engine": "Medelstor motor",
+ "heavy_engine": "Tung motor",
+ "engine_knocking": "Motorknackning",
+ "engine_starting": "Motor startar",
+ "idling": "Tomgång",
+ "accelerating": "Accelererar",
+ "ding-dong": "Ring-ring",
+ "sliding_door": "Skjutdörr",
+ "slam": "Smäll",
+ "knock": "Knack",
+ "tap": "Knacka",
+ "squeak": "Gnissla",
+ "cupboard_open_or_close": "Skåp öppnas eller stängs",
+ "drawer_open_or_close": "Låda öppnas eller stängs",
+ "dishes": "Tallrikar",
+ "cutlery": "Bestick",
+ "chopping": "Hackning",
+ "frying": "Steka",
+ "microwave_oven": "Mikrovågsugn",
+ "water_tap": "Vattenkran",
+ "bathtub": "Badkar",
+ "toilet_flush": "Toalettspolning",
+ "vacuum_cleaner": "Dammsugare",
+ "zipper": "Dragkedja",
+ "keys_jangling": "Nycklar som klirrar",
+ "coin": "Mynt",
+ "electric_shaver": "Elektrisk rakhyvel",
+ "shuffling_cards": "Blanda kort",
+ "typing": "Skrivar",
+ "typewriter": "Skrivmaskin",
+ "writing": "Skriva",
+ "telephone_bell_ringing": "Telefonen ringer",
+ "telephone_dialing": "Ljud för telefonuppringning",
+ "siren": "Siren",
+ "civil_defense_siren": "Civilförsvarssiren",
+ "buzzer": "Summer",
+ "foghorn": "Mistlur",
+ "whistle": "Vissla",
+ "steam_whistle": "Ångvissla",
+ "mechanisms": "Mekanismer",
+ "ratchet": "Spärrhake",
+ "tick": "Tick",
+ "tick-tock": "Tick Tack",
+ "gears": "Kugghjul",
+ "pulleys": "Remskivor",
+ "sewing_machine": "Symaskin",
+ "printer": "Skrivare",
+ "mechanical_fan": "Mekanisk fläkt",
+ "air_conditioning": "Luftkonditionering",
+ "cash_register": "Kassaapparat",
+ "single-lens_reflex_camera": "Enkellinsreflexkamera",
+ "tools": "Verktyg",
+ "hammer": "Hammare",
+ "jackhammer": "Tryckluftsborr",
+ "sawing": "Sågning",
+ "filing": "Filning",
+ "sanding": "Sandning",
+ "power_tool": "Elverktyg",
+ "drill": "Borra",
+ "explosion": "Explosion",
+ "gunshot": "Skottlossning",
+ "machine_gun": "Kulspruta",
+ "fusillade": "Fusillad",
+ "artillery_fire": "Artillerieeld",
+ "cap_gun": "Kapsylpistol",
+ "fireworks": "Fyrverkeri",
+ "firecracker": "Smällare",
+ "burst": "Brista",
+ "eruption": "Utbrott",
+ "boom": "Pang",
+ "wood": "Trä",
+ "chop": "Hugga",
+ "splinter": "Flisa",
+ "crack": "Spricka",
+ "glass": "Glas",
+ "chink": "Skaka",
+ "shatter": "Splittras",
+ "silence": "Tystnad",
+ "sound_effect": "Ljudeffekt",
+ "environmental_noise": "Miljöbuller",
+ "static": "Statisk",
+ "white_noise": "Vitt brus",
+ "pink_noise": "Rosa brus",
+ "television": "Tv",
+ "radio": "Radio",
+ "field_recording": "Fältinspelning",
+ "scream": "Skrika",
+ "sodeling": "Södling",
+ "chird": "Ackord",
+ "change_ringing": "Ljud från myntväxling",
+ "shofar": "Shofar",
+ "liquid": "Flytande",
+ "splash": "Stänk",
+ "slosh": "Plaska",
+ "squish": "Stryk",
+ "drip": "Dropp",
+ "pour": "Hälla",
+ "trickle": "Sippra",
+ "gush": "Välla",
+ "fill": "Fylla",
+ "spray": "Sprej",
+ "pump": "Pump",
+ "stir": "Rör",
+ "boiling": "Kokande",
+ "sonar": "Ekolod",
+ "arrow": "Pil",
+ "whoosh": "Svischande",
+ "thump": "Dunk",
+ "thunk": "Dunkande",
+ "electronic_tuner": "Elektronisk stämapparat",
+ "effects_unit": "Effektenhet",
+ "chorus_effect": "Chorus-effekt",
+ "basketball_bounce": "Basketbollstuds",
+ "bang": "Smäll",
+ "slap": "Slag",
+ "whack": "Slog",
+ "smash": "Smälla",
+ "breaking": "Brytning",
+ "bouncing": "Studsande",
+ "whip": "Piska",
+ "flap": "Flaxa",
+ "scratch": "Repa",
+ "scrape": "Skrapa",
+ "rub": "Gnugga",
+ "roll": "Rulla",
+ "crushing": "Krossa",
+ "crumpling": "Skrynkliga",
+ "tearing": "Rivning",
+ "beep": "Pip",
+ "ping": "Ping",
+ "ding": "Ding",
+ "clang": "Klang",
+ "squeal": "Skrika",
+ "creak": "Knarr",
+ "rustle": "Prassel",
+ "whir": "Surra",
+ "clatter": "Slammer",
+ "sizzle": "Fräsa vid matlagning",
+ "clicking": "Klickande",
+ "clickety_clack": "Klickigt klack",
+ "rumble": "Mullrande",
+ "plop": "Plopp",
+ "hum": "Brum",
+ "zing": "Vinande",
+ "boing": "Pling",
+ "crunch": "Knastrande",
+ "sine_wave": "Sinusvåg",
+ "harmonic": "Harmonisk",
+ "chirp_tone": "Kvittringston",
+ "pulse": "Puls",
+ "inside": "Inuti",
+ "outside": "Utanför",
+ "reverberation": "Eko",
+ "echo": "Eko",
+ "noise": "Buller",
+ "mains_hum": "Huvudbrum",
+ "distortion": "Distorsion",
+ "sidetone": "Sidoton",
+ "cacophony": "Kakofoni",
+ "throbbing": "Bultande",
+ "vibration": "Vibration"
}
diff --git a/web/public/locales/sv/common.json b/web/public/locales/sv/common.json
index a220db585..d6c185dff 100644
--- a/web/public/locales/sv/common.json
+++ b/web/public/locales/sv/common.json
@@ -16,10 +16,10 @@
"pm": "pm",
"am": "am",
"yr": "{{time}}år",
- "mo": "{{time}} mån",
+ "mo": "{{time}}må",
"month_one": "{{time}} månad",
"month_other": "{{time}} månader",
- "d": "{{time}}dag",
+ "d": "{{time}}d",
"last7": "Senaste 7 dagarna",
"5minutes": "5 minuter",
"last30": "Senaste 30 dagarna",
@@ -35,13 +35,13 @@
"12hour": "d MMM, yyyy",
"24hour": "d MMM, yyy"
},
- "h": "{{time}} h",
+ "h": "{{time}}t",
"hour_one": "{{time}} timme",
"hour_other": "{{time}} timmar",
- "m": "{{time}} m",
+ "m": "{{time}}m",
"minute_one": "{{time}} minut",
"minute_other": "{{time}} minuter",
- "s": "{{time}} s",
+ "s": "{{time}}s",
"formattedTimestamp": {
"12hour": "d MMM, kl. h:mm:ss a",
"24hour": "d MMM, HH:mm:ss"
@@ -72,7 +72,11 @@
"24hour": "dd-MM-yy-HH-mm-ss"
},
"day_one": "{{time}} dag",
- "day_other": "{{time}} dagar"
+ "day_other": "{{time}} dagar",
+ "inProgress": "Pågår",
+ "invalidStartTime": "Ogiltig starttid",
+ "invalidEndTime": "Ogiltig sluttid",
+ "never": "Aldrig"
},
"button": {
"save": "Spara",
@@ -104,48 +108,59 @@
"cameraAudio": "Kameraljud",
"on": "PÅ",
"off": "AV",
- "delete": "Släng",
+ "delete": "Radera",
"yes": "Ja",
"no": "Nej",
"download": "Ladda ner",
"info": "Info",
- "export": "Exportera"
+ "export": "Exportera",
+ "continue": "Fortsätta"
},
"menu": {
"language": {
- "yue": "Kantonesiska",
- "it": "Italienska",
- "fr": "Franska",
- "nl": "Nederländska (Dutch)",
- "hi": "Hindi",
- "pt": "Portugisiska",
- "ru": "Ryska",
- "pl": "Polska",
- "el": "Grekiska",
- "sk": "Slovenska",
- "tr": "Turkiska",
- "uk": "Ukrainska",
- "he": "Hebreiska",
- "ro": "Romänska",
- "hu": "Ungerska",
- "fi": "Finska",
- "da": "Danska",
- "ar": "Arabiska",
- "es": "Spanska",
- "zhCN": "Kinesiska",
- "de": "Tyska",
- "ja": "Japanska",
- "sv": "Svenska (Swedish)",
- "cs": "Tjeckiska (Czech)",
+ "yue": "粵語 (Kantonesiska)",
+ "it": "Italiano (Italienska)",
+ "fr": "Français (Franska)",
+ "nl": "Nederlands (Nederländska)",
+ "hi": "हिन्दी (Hindi)",
+ "pt": "Português (Portugisiska)",
+ "ru": "Русский (Ryska)",
+ "pl": "Polski (Polska)",
+ "el": "Ελληνικά (Grekiska)",
+ "sk": "Slovenčina (Slovenska)",
+ "tr": "Türkçe (Turkiska)",
+ "uk": "Українська (Ukrainska)",
+ "he": "עברית (Hebreiska)",
+ "ro": "Română (Romänska)",
+ "hu": "Magyar (Ungerska)",
+ "fi": "Suomi (Finska)",
+ "da": "Dansk (Danska)",
+ "ar": "العربية (Arabiska)",
+ "es": "Español (Spanska)",
+ "zhCN": "简体中文 (Kinesiska)",
+ "de": "Deutsch (Tyska)",
+ "ja": "日本語 (Japanska)",
+ "sv": "Svenska (Svenska)",
+ "cs": "Čeština (Tjeckiska)",
"nb": "Norsk Bokmål (Norsk Bokmål)",
- "ko": "Koreanska",
- "vi": "Vietnamesiska",
- "fa": "Persiska",
- "th": "Thailändska",
+ "ko": "한국어 (Koreanska)",
+ "vi": "Tiếng Việt (Vietnamesiska)",
+ "fa": "فارسی (Persiska)",
+ "th": "ไทย (Thailändska)",
"withSystem": {
"label": "Använd systeminställningarna för språk"
},
- "en": "Engelska"
+ "en": "English (Engelska)",
+ "ptBR": "Português brasileiro (Brasiliansk Portugisiska)",
+ "ca": "Català (Katalanska)",
+ "sr": "Српски (Serbiska)",
+ "sl": "Slovenščina (Slovenska)",
+ "lt": "Lietuvių (Litauiska)",
+ "bg": "Български (Bulgariska)",
+ "gl": "Galego (Galiciska)",
+ "id": "Bahasa Indonesia (Indonesiska)",
+ "ur": "اردو (Urdu)",
+ "hr": "Hrvatski (kroatiska)"
},
"darkMode": {
"withSystem": {
@@ -200,7 +215,8 @@
"languages": "Språk",
"configurationEditor": "Konfigurationsredigerare",
"withSystem": "System",
- "appearance": "Utseende"
+ "appearance": "Utseende",
+ "classification": "Klassificering"
},
"pagination": {
"next": {
@@ -241,7 +257,13 @@
"copyUrlToClipboard": "Webbadressen har kopierats till urklipp."
},
"label": {
- "back": "Gå tillbaka"
+ "back": "Gå tillbaka",
+ "hide": "Dölj {{item}}",
+ "show": "Visa {{item}}",
+ "ID": "ID",
+ "none": "Ingen",
+ "all": "Alla",
+ "other": "Annat"
},
"unit": {
"speed": {
@@ -251,7 +273,28 @@
"length": {
"feet": "fot",
"meters": "meter"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/timme",
+ "mbph": "MB/timme",
+ "gbph": "GB/timme"
}
},
- "selectItem": "Välj {{item}}"
+ "selectItem": "Välj {{item}}",
+ "readTheDocumentation": "Läs dokumentationen",
+ "information": {
+ "pixels": "{{area}}px"
+ },
+ "list": {
+ "two": "{{0}} och {{1}}",
+ "many": "{{items}} och {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Valfritt",
+ "internalID": "Det interna ID som Frigate använder i konfigurationen och databasen"
+ }
}
diff --git a/web/public/locales/sv/components/auth.json b/web/public/locales/sv/components/auth.json
index 8581ffe94..1fcf9092c 100644
--- a/web/public/locales/sv/components/auth.json
+++ b/web/public/locales/sv/components/auth.json
@@ -10,6 +10,7 @@
"unknownError": "Okänt fel. Kontrollera loggarna.",
"webUnknownError": "Okänt fel. Kontrollera konsol loggarna.",
"rateLimit": "Överskriden anropsgräns. Försök igen senare."
- }
+ },
+ "firstTimeLogin": "Försöker du logga in för första gången? Inloggningsuppgifterna finns angivna i Frigate-loggarna."
}
}
diff --git a/web/public/locales/sv/components/camera.json b/web/public/locales/sv/components/camera.json
index f4a3448db..23de9471f 100644
--- a/web/public/locales/sv/components/camera.json
+++ b/web/public/locales/sv/components/camera.json
@@ -62,7 +62,8 @@
"label": "Kompatibilitetsläge",
"desc": "Aktivera endast det här alternativet om kamerans livestream visar färgartefakter och har en diagonal linje på höger sida av bilden."
}
- }
+ },
+ "birdseye": "Fågelöga"
},
"cameras": {
"desc": "Välj kameror för denna guppen.",
diff --git a/web/public/locales/sv/components/dialog.json b/web/public/locales/sv/components/dialog.json
index 42af6ea41..2ef0e8814 100644
--- a/web/public/locales/sv/components/dialog.json
+++ b/web/public/locales/sv/components/dialog.json
@@ -3,21 +3,26 @@
"button": "Starta om",
"restarting": {
"title": "Frigate startar om",
- "content": "Sidan uppdateras om {{countdown}} seconds.",
- "button": "Tvinga uppdatering nu"
+ "content": "Sidan uppdateras om {{countdown}} sekunder.",
+ "button": "Tvinga omladdning nu"
},
"title": "Är du säker på att du vill starta om Frigate?"
},
"explore": {
"plus": {
"submitToPlus": {
- "label": "Skicka till Frigate+"
+ "label": "Skicka till Frigate+",
+ "desc": "Objekt på platser du vill undvika är inte falska positiva resultat. Att skicka in dem som falska positiva resultat kommer att förvirra modellen."
},
"review": {
"question": {
"ask_a": "Är detta objektet {{label}}?",
"ask_an": "Är detta objektet en {{label}}?",
- "ask_full": "Är detta objektet {{untranslatedLabel}} ({{translatedLabel}})?"
+ "ask_full": "Är detta objektet {{untranslatedLabel}} ({{translatedLabel}})?",
+ "label": "Bekräfta denna etikett för Frigate Plus"
+ },
+ "state": {
+ "submitted": "Inskickad"
}
}
},
@@ -29,7 +34,7 @@
"time": {
"fromTimeline": "Välj från tidslinjen",
"lastHour_one": "Sista timma",
- "lastHour_other": "Sista t {{count}} Timmarna",
+ "lastHour_other": "Sista {{count}} timmar",
"start": {
"title": "Start Tid",
"label": "Välj Start Tid"
@@ -37,12 +42,82 @@
"end": {
"title": "Slut Tid",
"label": "Välj Sluttid"
- }
+ },
+ "custom": "Anpassad"
},
"name": {
"placeholder": "Ge exporten ett namn"
},
"select": "Välj",
- "export": "Eksport"
+ "export": "Eksport",
+ "selectOrExport": "Välj eller exportera",
+ "toast": {
+ "success": "Exporten har startats. Visa filen på exportsidan.",
+ "error": {
+ "failed": "Misslyckades med att starta exporten: {{error}}",
+ "endTimeMustAfterStartTime": "Sluttiden måste vara efter starttiden",
+ "noVaildTimeSelected": "Inget giltigt tidsintervall valt"
+ },
+ "view": "Visa"
+ },
+ "fromTimeline": {
+ "saveExport": "Spara export",
+ "previewExport": "Förhandsgranska export"
+ }
+ },
+ "streaming": {
+ "label": "Videoström",
+ "restreaming": {
+ "disabled": "Omströmning är inte aktiverad för den här kameran.",
+ "desc": {
+ "title": "Konfigurera go2rtc för ytterligare livevisningsalternativ och ljud för den här kameran.",
+ "readTheDocumentation": "Läs dokumentationen"
+ }
+ },
+ "showStats": {
+ "label": "Visa strömstatistik",
+ "desc": "Aktivera det här alternativet för att visa strömstatistik som ett överlägg över kameraflödet."
+ },
+ "debugView": "Felsöknings vy"
+ },
+ "search": {
+ "saveSearch": {
+ "overwrite": "{{searchName}} finns redan. Om du sparar skrivs det befintliga värdet över.",
+ "success": "Sökningen ({{searchName}}) har sparats.",
+ "button": {
+ "save": {
+ "label": "Spara den här sökningen"
+ }
+ },
+ "label": "Spara Sökning",
+ "desc": "Ange ett namn för den här sparade sökningen.",
+ "placeholder": "Ange ett namn för din sökning"
+ }
+ },
+ "recording": {
+ "confirmDelete": {
+ "title": "Bekräfta radering",
+ "desc": {
+ "selected": "Är du säker på att du vill radera all inspelad video som är kopplad till det här granskningsobjektet?
Håll ner Shift-tangenten för att hoppa över den här dialogrutan i framtiden."
+ },
+ "toast": {
+ "success": "Videoklipp som är kopplade till de valda granskningsobjekten har raderats.",
+ "error": "Misslyckades med att ta bort: {{error}}"
+ }
+ },
+ "button": {
+ "export": "Exportera",
+ "markAsReviewed": "Markera som granskad",
+ "deleteNow": "Ta bort nu",
+ "markAsUnreviewed": "Markera som ogranskad"
+ }
+ },
+ "imagePicker": {
+ "selectImage": "Välj miniatyrbilden för ett spårat objekt",
+ "search": {
+ "placeholder": "Sök efter etikett eller underetikett..."
+ },
+ "noImages": "Inga miniatyrbilder hittades för den här kameran",
+ "unknownLabel": "Sparad triggerbild"
}
}
diff --git a/web/public/locales/sv/components/filter.json b/web/public/locales/sv/components/filter.json
index c29110cc7..efb50d919 100644
--- a/web/public/locales/sv/components/filter.json
+++ b/web/public/locales/sv/components/filter.json
@@ -9,17 +9,22 @@
"count_one": "{{count}} Etikett",
"count_other": "{{count}} Etiketter"
},
- "filter": "Filter",
+ "filter": "Filtrera",
"zones": {
"label": "Zoner",
"all": {
"title": "Alla zoner",
- "short": "Soner"
+ "short": "Zoner"
}
},
"features": {
"hasSnapshot": "Har ögonblicksbild",
- "hasVideoClip": "Har ett video klipp"
+ "hasVideoClip": "Har ett video klipp",
+ "submittedToFrigatePlus": {
+ "label": "Skickat till Frigate+",
+ "tips": "Du måste först filtrera på spårade objekt som har en ögonblicksbild.
Spårade objekt utan ögonblicksbild kan inte skickas till Frigate+."
+ },
+ "label": "Detaljer"
},
"sort": {
"dateAsc": "Datum (Stigande)",
@@ -42,12 +47,22 @@
"settings": {
"title": "Inställningar",
"defaultView": {
- "title": "Standard Vy"
+ "title": "Standard Vy",
+ "summary": "Sammanfattning",
+ "desc": "När inga filter är valda, visa en översikt av de senaste spårade objekten per etikett-typ eller visa ett ofiltrerat rutnät.",
+ "unfilteredGrid": "Ofiltrerat Rutnät"
},
"searchSource": {
"options": {
- "description": "Beskrivning"
- }
+ "description": "Beskrivning",
+ "thumbnailImage": "Miniatyrbild"
+ },
+ "label": "Sökkälla",
+ "desc": "Välj om du vill söka miniatyrbilderna eller beskrivningarna av de spårade objekten."
+ },
+ "gridColumns": {
+ "desc": "Välj antal kolumner i rutnätsvy.",
+ "title": "Kolumner i Rutnät"
}
},
"date": {
@@ -67,11 +82,18 @@
"all": {
"short": "Datum",
"title": "Alla datum"
- }
+ },
+ "selectPreset": "Välj Förval…"
},
"recognizedLicensePlates": {
"noLicensePlatesFound": "Inga registreringsplåtar hittade.",
- "selectPlatesFromList": "Välj en eller flera registreringsplåtar från listan."
+ "selectPlatesFromList": "Välj en eller flera registreringsplåtar från listan.",
+ "title": "Igenkända Registreringsskyltar",
+ "loadFailed": "Misslyckades med att ladda igenkända registreringsskyltar.",
+ "placeholder": "Skriv för att söka registreringsskyltar…",
+ "loading": "Laddar igenkända registreringsskyltar…",
+ "selectAll": "Välj alla",
+ "clearAll": "Rensa alla"
},
"more": "Flera filter",
"reset": {
@@ -81,5 +103,39 @@
"label": "Under kategori",
"all": "Alla under kategorier"
},
- "estimatedSpeed": "Estimerad hastighet ({{unit}})"
+ "estimatedSpeed": "Estimerad hastighet ({{unit}})",
+ "classes": {
+ "all": {
+ "title": "Alla Klasser"
+ },
+ "count_one": "{{count}} Klass",
+ "count_other": "{{count}} Klasser",
+ "label": "Klasser"
+ },
+ "timeRange": "Tidsspann",
+ "logSettings": {
+ "loading": {
+ "title": "Laddar",
+ "desc": "När loggvyn är rullad till slutet, strömmas automatiskt nya loggar till vyn."
+ },
+ "filterBySeverity": "Filtrera logg på allvarlighetsgrad",
+ "disableLogStreaming": "Inaktivera strömning av logg",
+ "allLogs": "Alla loggar",
+ "label": "Filter loggnivå"
+ },
+ "trackedObjectDelete": {
+ "title": "Bekräfta Borttagning",
+ "toast": {
+ "success": "Spårade objekt borttagna.",
+ "error": "Misslyckades med att ta bort spårade objekt: {{errorMessage}}"
+ },
+ "desc": "Borttagning av dessa {{objectLength}} spårade objekt tar bort ögonblicksbild, sparade inbäddningar, och tillhörande livscykelposter. Inspelat material av dessa spårade objekt i Historievyn kommer INTE att tas bort.
Vill du verkligen fortsätta?
Håll ner Skift-tangenten för att hoppa över denna dialog i framtiden."
+ },
+ "zoneMask": {
+ "filterBy": "Filtrera på zonmaskering"
+ },
+ "attributes": {
+ "label": "Klassificeringsattribut",
+ "all": "Alla attribut"
+ }
}
diff --git a/web/public/locales/sv/components/icons.json b/web/public/locales/sv/components/icons.json
index e15428582..afdcfb7d9 100644
--- a/web/public/locales/sv/components/icons.json
+++ b/web/public/locales/sv/components/icons.json
@@ -1,7 +1,7 @@
{
"iconPicker": {
"search": {
- "placeholder": "Sök efter ikon…"
+ "placeholder": "Sök efter en ikon…"
},
"selectIcon": "Välj en ikon"
}
diff --git a/web/public/locales/sv/components/input.json b/web/public/locales/sv/components/input.json
index b3081bd54..44c981f6e 100644
--- a/web/public/locales/sv/components/input.json
+++ b/web/public/locales/sv/components/input.json
@@ -1,9 +1,9 @@
{
"button": {
"downloadVideo": {
- "label": "Ladda ner Video",
+ "label": "Ladda ner video",
"toast": {
- "success": "Din video laddas ner."
+ "success": "Nedladdning påbörjad för granskningsobjekt."
}
}
}
diff --git a/web/public/locales/sv/components/player.json b/web/public/locales/sv/components/player.json
index b41c5dd65..7c6301ca1 100644
--- a/web/public/locales/sv/components/player.json
+++ b/web/public/locales/sv/components/player.json
@@ -1,5 +1,5 @@
{
- "noPreviewFound": "Ingen Förhandsvisning Hittad",
+ "noPreviewFound": "Ingen förhandsvisning hittad",
"noRecordingsFoundForThisTime": "Inga inspelningar hittade för denna tid",
"noPreviewFoundFor": "Ingen förhandsvisning hittad för {{cameraName}}",
"submitFrigatePlus": {
@@ -39,7 +39,7 @@
"decodedFrames": "Avkodade bildrutor:",
"droppedFrameRate": "Frekvens för bortfallna bildrutor:"
},
- "cameraDisabled": "Kameran är disablead",
+ "cameraDisabled": "Kameran är inaktiverad",
"toast": {
"error": {
"submitFrigatePlusFailed": "Bildruta har skickats till Frigate+ med misslyckat resultat"
diff --git a/web/public/locales/sv/objects.json b/web/public/locales/sv/objects.json
index 4b4da2cf9..1e2926ff3 100644
--- a/web/public/locales/sv/objects.json
+++ b/web/public/locales/sv/objects.json
@@ -80,7 +80,7 @@
"desk": "Skrivbord",
"toilet": "Toalett",
"tv": "TV",
- "laptop": "Laptop",
+ "laptop": "Bärbar dator",
"remote": "Fjärrkontroll",
"keyboard": "Tangentbord",
"cell_phone": "Mobiltelefon",
@@ -89,7 +89,7 @@
"vase": "Vas",
"scissors": "Sax",
"squirrel": "Ekorre",
- "deer": "Hjort",
+ "deer": "Rådjur",
"fox": "Räv",
"rabbit": "Kanin",
"raccoon": "Tvättbjörn",
@@ -110,9 +110,9 @@
"plate": "Tallrik",
"door": "Dörr",
"oven": "Ugn",
- "blender": "Mixer",
+ "blender": "Blandare",
"book": "Bok",
- "waste_bin": "Papperskorg",
+ "waste_bin": "Soptunna",
"license_plate": "Nummerplåt",
"toothbrush": "Tandborste",
"ups": "UPS",
diff --git a/web/public/locales/sv/views/classificationModel.json b/web/public/locales/sv/views/classificationModel.json
new file mode 100644
index 000000000..5b5c5b77f
--- /dev/null
+++ b/web/public/locales/sv/views/classificationModel.json
@@ -0,0 +1,188 @@
+{
+ "documentTitle": "Klassificeringsmodeller - Frigate",
+ "button": {
+ "deleteClassificationAttempts": "Ta bort klassificeringsbilder",
+ "renameCategory": "Byt namn på klass",
+ "deleteCategory": "Ta bort klass",
+ "deleteImages": "Ta bort bilder",
+ "trainModel": "Träna modellen",
+ "addClassification": "Lägg till klassificering",
+ "deleteModels": "Ta bort modeller",
+ "editModel": "Redigera modell"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Borttagen klass",
+ "deletedImage": "Raderade bilder",
+ "categorizedImage": "Lyckades klassificera bilden",
+ "trainedModel": "Modellen har tränats.",
+ "trainingModel": "Modellträning har startat.",
+ "deletedModel_one": "{{count}} modell har raderats",
+ "deletedModel_other": "{{count}} modeller har raderats",
+ "updatedModel": "Uppdaterade modellkonfiguration",
+ "renamedCategory": "Klassen har bytt namn till {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Misslyckades med att ta bort: {{errorMessage}}",
+ "deleteCategoryFailed": "Misslyckades med att ta bort klassen: {{errorMessage}}",
+ "categorizeFailed": "Misslyckades med att kategorisera bilden: {{errorMessage}}",
+ "trainingFailed": "Modellträningen misslyckades. Kontrollera Frigate loggarna för mer information.",
+ "deleteModelFailed": "Misslyckades med att ta bort modellen: {{errorMessage}}",
+ "updateModelFailed": "Misslyckades med att uppdatera modell: {{errorMessage}}",
+ "trainingFailedToStart": "Misslyckades med att starta modellträning: {{errorMessage}}",
+ "renameCategoryFailed": "Misslyckades med att byta namn på klassen: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Ta bort klass",
+ "desc": "Är du säker på att du vill ta bort klassen {{name}}? Detta kommer att ta bort alla associerade bilder permanent och kräva att modellen tränas om.",
+ "minClassesTitle": "Kan inte ta bort klassen",
+ "minClassesDesc": "En klassificeringsmodell måste ha minst två klasser. Lägg till ytterligare en klass innan du tar bort den här."
+ },
+ "deleteDatasetImages": {
+ "title": "Ta bort datamängdsbilder",
+ "desc_one": "Är du säker på att du vill ta bort {{count}} bild från {{dataset}}? Den här åtgärden kan inte ångras och kräver att modellen tränas om.",
+ "desc_other": "Är du säker på att du vill ta bort {{count}} bilder från {{dataset}}? Den här åtgärden kan inte ångras och kräver att modellen tränas om."
+ },
+ "deleteTrainImages": {
+ "title": "Ta bort tränade bilder",
+ "desc_one": "Är du säker på att du vill ta bort {{count}} bild? Den här åtgärden kan inte ångras.",
+ "desc_other": "Är du säker på att du vill ta bort {{count}} bilder? Den här åtgärden kan inte ångras."
+ },
+ "renameCategory": {
+ "title": "Byt namn på klass",
+ "desc": "Ange ett nytt namn för {{name}}. Du måste träna om modellen för att namnändringen ska träda i kraft."
+ },
+ "description": {
+ "invalidName": "Ogiltigt namn. Namn får endast innehålla bokstäver, siffror, mellanslag, apostrofer, understreck och bindestreck."
+ },
+ "train": {
+ "title": "Nyligen tillagd klassificeringar",
+ "aria": "Välj senaste klassificeringar",
+ "titleShort": "Ny"
+ },
+ "categories": "Klasser",
+ "createCategory": {
+ "new": "Skapa ny klass"
+ },
+ "categorizeImageAs": "Klassificera bilden som:",
+ "categorizeImage": "Klassificera bild",
+ "noModels": {
+ "object": {
+ "title": "Inga objektklassificeringsmodeller",
+ "description": "Skapa en anpassad modell för att klassificera detekterade objekt.",
+ "buttonText": "Skapa objektmodell"
+ },
+ "state": {
+ "title": "Inga tillstånd klassificeringsmodeller",
+ "description": "Skapa en anpassad modell för att övervaka och klassificera tillståndsförändringar i specifika kameraområden.",
+ "buttonText": "Skapa en tillståndsmodell"
+ }
+ },
+ "wizard": {
+ "title": "Skapa ny klassificering",
+ "steps": {
+ "nameAndDefine": "Namnge och definiera",
+ "stateArea": "Stat område",
+ "chooseExamples": "Välj exempel"
+ },
+ "step1": {
+ "description": "Tillståndsmodeller övervakar fasta kameraområden för förändringar (t.ex. dörr öppen/stängd). Objektmodeller lägger till klassificeringar till detekterade objekt (t.ex. kända djur, leveranspersoner etc.).",
+ "name": "Namn",
+ "namePlaceholder": "Ange modellnamn...",
+ "type": "Typ",
+ "typeState": "Tillståndet",
+ "typeObject": "Objekt",
+ "objectLabel": "Objektetikett",
+ "objectLabelPlaceholder": "Välj objekttyp...",
+ "classificationType": "Klassificeringstyp",
+ "classificationTypeTip": "Lär dig mer om klassificeringstyper",
+ "classificationTypeDesc": "Underetiketter lägger till ytterligare text till objektetiketten (t.ex. 'Person: UPS'). Attribut är sökbara metadata som lagras separat i objektmetadata.",
+ "classificationSubLabel": "Underetikett",
+ "classificationAttribute": "Attribut",
+ "classes": "Klasser",
+ "states": "Tillstånd",
+ "classesTip": "Lär dig mer om klasser",
+ "classesStateDesc": "Definiera de olika tillstånd som ditt kameraområde kan vara i. Till exempel: \"öppen\" och \"stängd\" för en garageport.",
+ "classesObjectDesc": "Definiera de olika kategorierna som detekterade objekt ska klassificeras i. Till exempel: 'leveransperson', 'boende', 'främling' för personklassificering.",
+ "classPlaceholder": "Ange klassnamn...",
+ "errors": {
+ "nameRequired": "Modellnamn krävs",
+ "nameLength": "Modellnamnet måste vara högst 64 tecken långt",
+ "nameOnlyNumbers": "Modellnamnet får inte bara innehålla siffror",
+ "classRequired": "Minst 1 klass krävs",
+ "classesUnique": "Klassnamn måste vara unika",
+ "stateRequiresTwoClasses": "Tillståndsmodeller kräver minst två klasser",
+ "objectLabelRequired": "Välj en objektetikett",
+ "objectTypeRequired": "Vänligen välj en klassificeringstyp",
+ "noneNotAllowed": "Klassen 'none' är inte tillåten"
+ }
+ },
+ "step2": {
+ "description": "Välj kameror och definiera området som ska övervakas för varje kamera. Modellen kommer att klassificera tillståndet för dessa områden.",
+ "cameras": "Kameror",
+ "selectCamera": "Välj kamera",
+ "noCameras": "Klicka på + för att lägga till kameror",
+ "selectCameraPrompt": "Välj en kamera från listan för att definiera dess övervakningsområde"
+ },
+ "step3": {
+ "selectImagesPrompt": "Markera alla bilder med: {{className}}",
+ "selectImagesDescription": "Klicka på bilderna för att välja dem. Klicka på Fortsätt när du är klar med den här klass.",
+ "generating": {
+ "title": "Generera exempelbilder",
+ "description": "Frigate hämtar representativa bilder från dina inspelningar. Det kan ta en stund..."
+ },
+ "training": {
+ "title": "Träningsmodell",
+ "description": "Din modell tränas i bakgrunden. Stäng den här dialogrutan så börjar modellen köras så snart träningen är klar."
+ },
+ "retryGenerate": "Försök att generera igen",
+ "noImages": "Inga exempelbilder genererade",
+ "classifying": "Klassificering & Träning...",
+ "trainingStarted": "Träningen har börjat",
+ "errors": {
+ "noCameras": "Inga kameror konfigurerade",
+ "noObjectLabel": "Ingen objektetikett vald",
+ "generateFailed": "Misslyckades med att generera exempel: {{error}}",
+ "generationFailed": "Genereringen misslyckades. Försök igen.",
+ "classifyFailed": "Misslyckades med att klassificera bilder: {{error}}"
+ },
+ "generateSuccess": "Exempelbilder har genererats",
+ "allImagesRequired_one": "Vänligen klassificera alla bilder. {{count}} bild återstår.",
+ "allImagesRequired_other": "Vänligen klassificera alla bilder. {{count}} bilder återstår.",
+ "modelCreated": "Modellen har skapats. Använd vyn Senaste klassificeringar för att lägga till bilder för saknade tillstånd och träna sedan modellen.",
+ "missingStatesWarning": {
+ "title": "Exempel på saknade tillstånd",
+ "description": "Det rekommenderas att välja exempel för alla tillstånd för bästa resultat. Du kan fortsätta utan att välja alla tillstånd, men modellen kommer inte att tränas förrän alla tillstånd har bilder. När du har fortsatt använder du vyn Senaste klassificeringar för att klassificera bilder för de saknade tillstånden och tränar sedan modellen."
+ }
+ }
+ },
+ "deleteModel": {
+ "title": "Ta bort klassificeringsmodell",
+ "single": "Är du säker på att du vill ta bort {{name}}? Detta kommer att permanent ta bort all tillhörande data, inklusive bilder och träningsdata. Åtgärden kan inte ångras.",
+ "desc_one": "Är du säker på att du vill ta bort {{count}} modell? Detta kommer att permanent ta bort all tillhörande data, inklusive bilder och träningsdata. Åtgärden kan inte ångras.",
+ "desc_other": "Är du säker på att du vill ta bort {{count}} modeller? Detta kommer att permanent ta bort all tillhörande data, inklusive bilder och träningsdata. Åtgärden kan inte ångras."
+ },
+ "menu": {
+ "objects": "Objekt",
+ "states": "Tillstånd"
+ },
+ "details": {
+ "scoreInfo": "Poängen representerar den genomsnittliga klassificeringssäkerheten för alla upptäckter av detta objekt.",
+ "none": "Ingen",
+ "unknown": "Okänd"
+ },
+ "edit": {
+ "title": "Redigera klassificeringsmodell",
+ "descriptionState": "Redigera klasserna för denna tillståndsklassificeringsmodell. Ändringar kräver omträning av modellen.",
+ "descriptionObject": "Redigera objekttyp och klassificeringstyp för denna objektklassificeringsmodell.",
+ "stateClassesInfo": "Observera: För att ändra tillståndsklasser måste modellen omtränas med de uppdaterade klasserna."
+ },
+ "tooltip": {
+ "trainingInProgress": "Modellen tränar för närvarande",
+ "noNewImages": "Inga nya bilder att träna. Klassificera fler bilder i datasetet först.",
+ "noChanges": "Inga ändringar i datamängden sedan senaste träningen.",
+ "modelNotReady": "Modellen är inte redo för träning"
+ },
+ "none": "Ingen"
+}
diff --git a/web/public/locales/sv/views/configEditor.json b/web/public/locales/sv/views/configEditor.json
index 27409c968..7b96ff9fe 100644
--- a/web/public/locales/sv/views/configEditor.json
+++ b/web/public/locales/sv/views/configEditor.json
@@ -12,5 +12,7 @@
},
"documentTitle": "Ändra konfiguration - Frigate",
"configEditor": "Ändra konfiguration",
- "confirm": "Avsluta utan att spara?"
+ "confirm": "Avsluta utan att spara?",
+ "safeConfigEditor": "Konfigurationsredigeraren (felsäkert läge)",
+ "safeModeDescription": "Fregate är i felsäkert läge på grund av ett konfigurationsvalideringsfel."
}
diff --git a/web/public/locales/sv/views/events.json b/web/public/locales/sv/views/events.json
index 9536f9b3d..f849a43a2 100644
--- a/web/public/locales/sv/views/events.json
+++ b/web/public/locales/sv/views/events.json
@@ -9,7 +9,11 @@
"empty": {
"alert": "Det finns inga varningar att granska",
"detection": "Det finns inga detekteringar att granska",
- "motion": "Ingen rörelsedata hittad"
+ "motion": "Ingen rörelsedata hittad",
+ "recordingsDisabled": {
+ "title": "Inspelningar måste vara aktiverat",
+ "description": "Granskningsobjekt kan bara skapas för en kamera när inspelningar är aktiverat för den kameran."
+ }
},
"documentTitle": "Granska - Frigate",
"timeline": "Tidslinje",
@@ -34,5 +38,30 @@
"markTheseItemsAsReviewed": "Markera dessa objekt som granskade",
"detected": "upptäckt",
"selected_one": "{{count}} valda",
- "selected_other": "{{count}} valda"
+ "selected_other": "{{count}} valda",
+ "suspiciousActivity": "Misstänkt aktivitet",
+ "threateningActivity": "Hotande aktivitet",
+ "detail": {
+ "noDataFound": "Inga detaljerade data att granska",
+ "aria": "Växla detaljvy",
+ "trackedObject_one": "{{count}} objekt",
+ "trackedObject_other": "{{count}} objekt",
+ "noObjectDetailData": "Inga objektdetaljdata tillgängliga.",
+ "label": "Detalj",
+ "settings": "Detaljvy inställningar",
+ "alwaysExpandActive": {
+ "title": "Expandera alltid aktivt",
+ "desc": "Expandera alltid objektinformationen för det aktiva granskningsobjektet när den är tillgänglig."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Spårad punkt",
+ "clickToSeek": "Klicka för att söka till den här tiden"
+ },
+ "zoomIn": "Zooma in",
+ "zoomOut": "Zooma ut",
+ "normalActivity": "Normal",
+ "needsReview": "Behöver granskas",
+ "securityConcern": "Säkerhetsproblem",
+ "select_all": "Alla"
}
diff --git a/web/public/locales/sv/views/explore.json b/web/public/locales/sv/views/explore.json
index e8cecd73f..b6355ea2c 100644
--- a/web/public/locales/sv/views/explore.json
+++ b/web/public/locales/sv/views/explore.json
@@ -5,25 +5,299 @@
"embeddingsReindexing": {
"startingUp": "Startar upp…",
"estimatedTime": "Beräknad återstående tid:",
- "finishingShortly": "Snart klar"
+ "finishingShortly": "Snart klar",
+ "context": "Utforskaren kan användas efter inbäddade spårade objekt har slutat återindexerat.",
+ "step": {
+ "thumbnailsEmbedded": "Miniatyrbilder inbäddad: ",
+ "descriptionsEmbedded": "Beskrivningar inbäddade: ",
+ "trackedObjectsProcessed": "Spårade objekt bearbetad: "
+ }
},
"title": "Utforska är inte tillgänglig",
"downloadingModels": {
"setup": {
- "textModel": "Text modell"
+ "textModel": "Text modell",
+ "visionModel": "Visionsmodell",
+ "visionModelFeatureExtractor": "Funktionsutdragare för visionsmodell",
+ "textTokenizer": "Texttokeniserare"
},
"tips": {
- "documentation": "Läs dokumentationen"
+ "documentation": "Läs dokumentationen",
+ "context": "Du kanske vill omindexera inbäddningarna av dina spårade objekt när modellerna har laddats ner."
},
- "error": "Ett fel har inträffat. Kontrollera Frigate loggarna."
+ "error": "Ett fel har inträffat. Kontrollera Frigate loggarna.",
+ "context": "Frigate laddar ner de nödvändiga inbäddningsmodellerna för att stödja den semantiska sökfunktionen. Detta kan ta flera minuter beroende på hastigheten på din nätverksanslutning."
}
},
"details": {
- "timestamp": "tidsstämpel"
+ "timestamp": "tidsstämpel",
+ "item": {
+ "title": "Granska objektinformation",
+ "desc": "Granska objektinformation",
+ "button": {
+ "share": "Dela den här recensionen",
+ "viewInExplore": "Visa i Utforska"
+ },
+ "tips": {
+ "mismatch_one": "{{count}} otillgängligt objekt upptäcktes och inkluderades i detta granskningsobjekt. Dessa objekt kvalificerade sig antingen inte som en varning eller detektering, eller så har de redan rensats/raderats.",
+ "mismatch_other": "{{count}} otillgängliga objekt upptäcktes och inkluderades i detta granskningsobjekt. Dessa objekt kvalificerade sig antingen inte som en varning eller upptäckt, eller så har de redan rensats/raderats.",
+ "hasMissingObjects": "Justera din konfiguration om du vill att Frigate ska spara spårade objekt för följande etiketter: {{objects}}"
+ },
+ "toast": {
+ "success": {
+ "regenerate": "En ny beskrivning har begärts från {{provider}}. Beroende på din leverantörs hastighet kan det ta lite tid att generera den nya beskrivningen.",
+ "updatedSublabel": "Underetiketten har uppdaterats.",
+ "updatedLPR": "Nummerplåt har uppdaterats.",
+ "audioTranscription": "Ljudtranskription har begärts. Beroende på hastigheten på din Frigate-server kan transkriptionen ta lite tid att slutföra.",
+ "updatedAttributes": "Attributen har uppdaterats."
+ },
+ "error": {
+ "regenerate": "Kunde inte ringa {{provider}} för en ny beskrivning: {{errorMessage}}",
+ "updatedSublabelFailed": "Misslyckades med att uppdatera underetiketten: {{errorMessage}}",
+ "audioTranscription": "Misslyckades med att begära ljudtranskription: {{errorMessage}}",
+ "updatedLPRFailed": "Misslyckades med att uppdatera nummerplåten: {{errorMessage}}",
+ "updatedAttributesFailed": "Misslyckades med att uppdatera attribut: {{errorMessage}}"
+ }
+ }
+ },
+ "label": "Märka",
+ "editSubLabel": {
+ "title": "Redigera underetikett",
+ "desc": "Ange en ny underetikett för denna {{label}}",
+ "descNoLabel": "Ange en ny underetikett för det här spårade objektet"
+ },
+ "editLPR": {
+ "title": "Redigera nummerplåt",
+ "desc": "Ange ett nytt nummerplåt för denna {{label}}",
+ "descNoLabel": "Ange ett nytt nummerplåt för detta spårade objekt"
+ },
+ "snapshotScore": {
+ "label": "Ögonblicksbildspoäng"
+ },
+ "topScore": {
+ "label": "Högsta poäng",
+ "info": "Topppoängen är den högsta medianpoängen för det spårade objektet, så denna kan skilja sig från poängen som visas på miniatyrbilden av sökresultatet."
+ },
+ "score": {
+ "label": "Poäng"
+ },
+ "recognizedLicensePlate": "Erkänd nummerplåt",
+ "estimatedSpeed": "Uppskattad hastighet",
+ "objects": "Objekt",
+ "camera": "Kamera",
+ "zones": "Zoner",
+ "button": {
+ "findSimilar": "Hitta liknande",
+ "regenerate": {
+ "title": "Regenerera",
+ "label": "Återskapa beskrivningen av spårat objekt"
+ }
+ },
+ "description": {
+ "label": "Beskrivning",
+ "placeholder": "Beskrivning av det spårade objektet",
+ "aiTips": "Frigate kommer inte att begära en beskrivning från din generativa AI-leverantör förrän det spårade objektets livscykel har avslutats."
+ },
+ "expandRegenerationMenu": "Expandera regenereringsmenyn",
+ "regenerateFromSnapshot": "Återskapa från ögonblicksbild",
+ "regenerateFromThumbnails": "Återskapa från miniatyrbilder",
+ "tips": {
+ "descriptionSaved": "Beskrivningen har sparats",
+ "saveDescriptionFailed": "Misslyckades med att uppdatera beskrivningen: {{errorMessage}}"
+ },
+ "editAttributes": {
+ "title": "Redigera attribut",
+ "desc": "Välj klassificeringsattribut för denna {{label}}"
+ },
+ "attributes": "Klassificeringsattribut",
+ "title": {
+ "label": "Titel"
+ }
},
"exploreMore": "Utforska fler {{label}} objekt",
"type": {
"details": "detaljer",
- "video": "video"
+ "video": "video",
+ "snapshot": "ögonblicksbild",
+ "object_lifecycle": "objektets livscykel",
+ "thumbnail": "miniatyrbild",
+ "tracking_details": "spårningsdetaljer"
+ },
+ "trackedObjectDetails": "Detaljer om spårade objekt",
+ "objectLifecycle": {
+ "title": "Objektets livscykel",
+ "noImageFound": "Ingen bild hittades för denna tidsstämpel.",
+ "createObjectMask": "Skapa objektmask",
+ "adjustAnnotationSettings": "Justera annoteringsinställningar",
+ "scrollViewTips": "Scrolla för att se de viktiga ögonblicken i detta objekts livscykel.",
+ "autoTrackingTips": "Begränsningsrutornas positioner kommer att vara felaktiga för autospårningskameror.",
+ "count": "{{first}} av {{second}}",
+ "lifecycleItemDesc": {
+ "external": "{{label}} upptäckt",
+ "header": {
+ "zones": "Zoner",
+ "ratio": "Proportion",
+ "area": "Område"
+ },
+ "visible": "{{label}} upptäckt",
+ "entered_zone": "{{label}} gick in i {{zones}}",
+ "active": "{{label}} blev aktiv",
+ "stationary": "{{label}} blev stationär",
+ "attribute": {
+ "faceOrLicense_plate": "{{attribute}} upptäckt för {{label}}",
+ "other": "{{label}} igenkänd som {{attribute}}"
+ },
+ "gone": "{{label}} vänster",
+ "heard": "{{label}} hört"
+ },
+ "annotationSettings": {
+ "title": "Annoteringsinställningar",
+ "showAllZones": {
+ "title": "Visa alla zoner",
+ "desc": "Visa alltid zoner på ramar där objekt har kommit in i en zon."
+ },
+ "offset": {
+ "label": "Annoteringsförskjutning",
+ "desc": "Denna data kommer från din kameras detekteringsflöde men läggs ovanpå bilder från inspelningsflödet. Det är osannolikt att de två strömmarna är helt synkroniserade. Som ett resultat kommer avgränsningsramen och filmmaterialet inte att radas upp perfekt. Fältet annotation_offset kan dock användas för att justera detta.",
+ "documentation": "Läs dokumentationen ",
+ "millisecondsToOffset": "Millisekunder för att förskjuta detektera annoteringar med. Standard: 0",
+ "tips": "TIPS: Föreställ dig ett händelseklipp med en person som går från vänster till höger. Om tidslinjens avgränsningsram konsekvent är till vänster om personen bör värdet minskas. På samma sätt, om en person går från vänster till höger och avgränsningsramen konsekvent är framför personen bör värdet ökas.",
+ "toast": {
+ "success": "Annoterings förskjutningen för {{camera}} har sparats i konfigurationsfilen. Starta om Frigate för att tillämpa dina ändringar."
+ }
+ }
+ },
+ "trackedPoint": "Spårad punkt",
+ "carousel": {
+ "previous": "Föregående bild",
+ "next": "Nästa bild"
+ }
+ },
+ "itemMenu": {
+ "downloadVideo": {
+ "label": "Ladda ner video",
+ "aria": "Ladda ner video"
+ },
+ "downloadSnapshot": {
+ "label": "Ladda ner ögonblicksbild",
+ "aria": "Ladda ner ögonblicksbild"
+ },
+ "viewObjectLifecycle": {
+ "label": "Visa objektets livscykel",
+ "aria": "Visa objektets livscykel"
+ },
+ "findSimilar": {
+ "label": "Hitta liknande",
+ "aria": "Hitta liknande spårade objekt"
+ },
+ "addTrigger": {
+ "label": "Lägg till utlösare",
+ "aria": "Lägg till en utlösare för det här spårade objektet"
+ },
+ "audioTranscription": {
+ "label": "Transkribera",
+ "aria": "Begär ljudtranskribering"
+ },
+ "submitToPlus": {
+ "label": "Skicka till Frigate+",
+ "aria": "Skicka till Frigate Plus"
+ },
+ "viewInHistory": {
+ "label": "Visa i historik",
+ "aria": "Visa i historik"
+ },
+ "deleteTrackedObject": {
+ "label": "Ta bort det här spårade objektet"
+ },
+ "showObjectDetails": {
+ "label": "Visa objektets plats"
+ },
+ "viewTrackingDetails": {
+ "label": "Visa spårningsinformation",
+ "aria": "Visa spårningsdetaljerna"
+ },
+ "hideObjectDetails": {
+ "label": "Dölj objektsökväg"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Ladda ner ren ögonblicksbild",
+ "aria": "Ladda ner ren ögonblicksbild"
+ }
+ },
+ "dialog": {
+ "confirmDelete": {
+ "title": "Bekräfta radering",
+ "desc": "Om du tar bort det här spårade objektet tas ögonblicksbilden, alla sparade inbäddningar och alla tillhörande spårningsdetaljer bort. Inspelade bilder av det här spårade objektet i historikvyn kommer INTE att raderas.
Är du säker på att du vill fortsätta?"
+ }
+ },
+ "noTrackedObjects": "Inga spårade objekt hittades",
+ "fetchingTrackedObjectsFailed": "Fel vid hämtning av spårade objekt: {{errorMessage}}",
+ "trackedObjectsCount_one": "{{count}} spårat objekt ",
+ "trackedObjectsCount_other": "{{count}} spårade objekt ",
+ "searchResult": {
+ "tooltip": "Matchade {{type}} vid {{confidence}}%",
+ "deleteTrackedObject": {
+ "toast": {
+ "success": "Spårat objekt har raderats.",
+ "error": "Misslyckades med att ta bort spårat objekt: {{errorMessage}}"
+ }
+ },
+ "previousTrackedObject": "Föregående spårade objekt",
+ "nextTrackedObject": "Nästa spårade objekt"
+ },
+ "aiAnalysis": {
+ "title": "AI-analys"
+ },
+ "concerns": {
+ "label": "Oro"
+ },
+ "trackingDetails": {
+ "title": "Spårningsdetaljer",
+ "noImageFound": "Ingen bild hittades för denna tidsstämpel.",
+ "createObjectMask": "Skapa objektmask",
+ "adjustAnnotationSettings": "Justera annoteringsinställningar",
+ "scrollViewTips": "Klicka för att se de viktiga ögonblicken i detta objekts livscykel.",
+ "autoTrackingTips": "Begränsningsrutornas positioner kommer att vara felaktiga för autospårningskameror.",
+ "count": "{{first}} av {{second}}",
+ "trackedPoint": "Spårad punkt",
+ "lifecycleItemDesc": {
+ "visible": "{{label}} upptäckt",
+ "entered_zone": "{{label}} gick in i {{zones}}",
+ "active": "{{label}} blev aktiv",
+ "stationary": "{{label}} blev stationär",
+ "attribute": {
+ "faceOrLicense_plate": "{{attribute}} upptäckt för {{label}}",
+ "other": "{{label}} igenkänd som {{attribute}}"
+ },
+ "gone": "{{label}} lämnade",
+ "heard": "{{label}} hördes",
+ "external": "{{label}} upptäckt",
+ "header": {
+ "zones": "Zoner",
+ "ratio": "Förhållandet",
+ "area": "Område",
+ "score": "Resultat"
+ }
+ },
+ "annotationSettings": {
+ "title": "Annoteringsinställningar",
+ "showAllZones": {
+ "title": "Visa alla zoner",
+ "desc": "Visa alltid zoner på ramar där objekt har kommit in i en zon."
+ },
+ "offset": {
+ "label": "Annoteringsförskjutning",
+ "desc": "Denna data kommer från din kameras detekteringsflöde men läggs ovanpå bilder från inspelningsflödet. Det är osannolikt att de två strömmarna är helt synkroniserade. Som ett resultat kommer avgränsningsramen och filmmaterialet inte att radas upp perfekt. Du kan använda den här inställningen för att förskjuta anteckningarna framåt eller bakåt i tiden för att bättre anpassa dem till det inspelade materialet.",
+ "millisecondsToOffset": "Millisekunder för att förskjuta detektera annoteringar med. Standard: 0",
+ "tips": "TIPS: Föreställ dig ett händelseklipp med en person som går från vänster till höger. Om tidslinjens avgränsningsram konsekvent är till vänster om personen bör värdet minskas. På samma sätt, om en person går från vänster till höger och avgränsningsramen konsekvent är framför personen bör värdet ökas.",
+ "toast": {
+ "success": "Annoteringsförskjutningen för {{camera}} har sparats i konfigurationsfilen."
+ }
+ }
+ },
+ "carousel": {
+ "previous": "Föregående bild",
+ "next": "Nästa bild"
+ }
}
}
diff --git a/web/public/locales/sv/views/exports.json b/web/public/locales/sv/views/exports.json
index f5b8f37b5..da2bc1324 100644
--- a/web/public/locales/sv/views/exports.json
+++ b/web/public/locales/sv/views/exports.json
@@ -13,5 +13,11 @@
"error": {
"renameExportFailed": "Misslyckades att byta namn på export: {{errorMessage}}"
}
+ },
+ "tooltip": {
+ "shareExport": "Dela export",
+ "downloadVideo": "Ladda ner video",
+ "editName": "Redigera namn",
+ "deleteExport": "Ta bort export"
}
}
diff --git a/web/public/locales/sv/views/faceLibrary.json b/web/public/locales/sv/views/faceLibrary.json
index 763f7533c..76a80ce92 100644
--- a/web/public/locales/sv/views/faceLibrary.json
+++ b/web/public/locales/sv/views/faceLibrary.json
@@ -4,33 +4,99 @@
"confidence": "Säkerhet",
"face": "Ansiktsdetaljer",
"timestamp": "tidsstämpel",
- "faceDesc": "Detaljer för ansiktet och tillhörande objekt",
- "unknown": "Okänt"
+ "faceDesc": "Detaljer om det spårade objektet som genererade detta ansikte",
+ "unknown": "Okänd",
+ "subLabelScore": "Underetikettpoäng",
+ "scoreInfo": "Underetikettpoängen är den viktade poängen för alla igenkända ansiktskonfidenser, så detta kan skilja sig från poängen som visas på ögonblicksbilden."
},
"description": {
"placeholder": "Ange ett namn för denna samling",
- "addFace": "Gå genom för att lägga till nya ansikte till biblioteket.",
- "invalidName": "Felaktigt namn. Namn kan endast innehålla bokstäver, siffror, mellanslag, apostrofer, understreck och bindestreck."
+ "addFace": "Lägg till en ny samling i ansiktsbiblioteket genom att ladda upp din första bild.",
+ "invalidName": "Ogiltigt namn. Namn får endast innehålla bokstäver, siffror, mellanslag, apostrofer, understreck och bindestreck.",
+ "nameCannotContainHash": "Namn får inte innehålla #."
},
"documentTitle": "Ansiktsbibliotek - Frigate",
"steps": {
"faceName": "Ange namn",
"uploadFace": "Ladda upp bild på ansikte",
- "nextSteps": "Nästa steg"
+ "nextSteps": "Nästa steg",
+ "description": {
+ "uploadFace": "Ladda upp en bild på {{name}} som visar deras ansikte framifrån. Bilden behöver inte beskäras till bara deras ansikte."
+ }
},
"createFaceLibrary": {
"title": "Skapa samling",
"desc": "Skapa ny samling",
- "nextSteps": "För att bygga en stark grund:Använd fliken Träna för att välja och träna på bilder för varje upptäckt person. Fokusera på raka bilder för bästa resultat; undvik träningsbilder som fångar ansikten i vinkel. ",
+ "nextSteps": "För att bygga en stark grund:Använd fliken Senaste Igenkänningar för att välja och träna bilder för varje detekterad person. Fokusera på raka bilder för bästa resultat; undvik att träna bilder som fångar ansikten i en vinkel. ",
"new": "Skapa nytt ansikte"
},
"train": {
- "title": "Träna"
+ "title": "Senaste Igenkänningar",
+ "aria": "Välj senaste igenkänningar",
+ "empty": "Det finns inga ny försök till ansiktsigenkänning",
+ "titleShort": "Ny"
},
"uploadFaceImage": {
"title": "Ladda upp ansiktsbild",
"desc": "Ladda upp en bild för att skanna efter ansikte och inkludera {{pageToggle}}"
},
"selectItem": "Välj {{item}}",
- "collections": "Samlingar"
+ "collections": "Samlingar",
+ "selectFace": "Välj ansikte",
+ "deleteFaceLibrary": {
+ "title": "Ta bort namn",
+ "desc": "Är du säker på att du vill ta bort samlingen {{name}}? Detta kommer att ta bort alla associerade ansikten permanent."
+ },
+ "deleteFaceAttempts": {
+ "title": "Ta bort ansikten",
+ "desc_one": "Är du säker på att du vill ta bort {{count}} ansikte? Den här åtgärden kan inte ångras.",
+ "desc_other": "Är du säker på att du vill ta bort {{count}} ansikten? Den här åtgärden kan inte ångras."
+ },
+ "imageEntry": {
+ "dropActive": "Släpp bilden här…",
+ "dropInstructions": "Dra och släpp eller klistra in en bild här, eller klicka för att välja",
+ "maxSize": "Maxstorlek: {{size}}MB",
+ "validation": {
+ "selectImage": "Välj en bildfil."
+ }
+ },
+ "nofaces": "Inga ansikten tillgängliga",
+ "pixels": "{{area}}px",
+ "readTheDocs": "Läs dokumentationen",
+ "trainFaceAs": "Träna ansikte som:",
+ "trainFace": "Träna ansikte",
+ "toast": {
+ "success": {
+ "uploadedImage": "Bilden har laddats upp.",
+ "addFaceLibrary": "{{name}} har lagts till i ansiktsbiblioteket!",
+ "deletedFace_one": "{{count}} ansikte har raderats.",
+ "deletedFace_other": "{{count}} ansikten har raderats.",
+ "deletedName_one": "{{count}} ansikte har raderats.",
+ "deletedName_other": "{{count}} ansikten har raderats.",
+ "renamedFace": "Ansiktet har bytt namn till {{name}}",
+ "trainedFace": "Ansikte är tränant.",
+ "updatedFaceScore": "Ansikts poängen har uppdaterats."
+ },
+ "error": {
+ "uploadingImageFailed": "Misslyckades med att ladda upp bilden: {{errorMessage}}",
+ "addFaceLibraryFailed": "Misslyckades med att ange ansiktsnamn: {{errorMessage}}",
+ "deleteFaceFailed": "Misslyckades med att ta bort: {{errorMessage}}",
+ "deleteNameFailed": "Misslyckades med att ta bort namnet: {{errorMessage}}",
+ "renameFaceFailed": "Misslyckades med att byta namn på ansikte: {{errorMessage}}",
+ "trainFailed": "Misslyckades med att träna: {{errorMessage}}",
+ "updateFaceScoreFailed": "Misslyckades med att uppdatera ansiktspoäng: {{errorMessage}}"
+ }
+ },
+ "renameFace": {
+ "title": "Byt namn på ansikte",
+ "desc": "Ange ett nytt namn för {{name}}"
+ },
+ "button": {
+ "deleteFaceAttempts": "Ta bort ansikten",
+ "addFace": "Lägg till ansikte",
+ "renameFace": "Byt namn på ansikte",
+ "deleteFace": "Ta bort ansikte",
+ "uploadImage": "Ladda upp bild",
+ "reprocessFace": "Återbearbeta ansiktet"
+ }
}
diff --git a/web/public/locales/sv/views/live.json b/web/public/locales/sv/views/live.json
index ff6d2a4c2..750fdd836 100644
--- a/web/public/locales/sv/views/live.json
+++ b/web/public/locales/sv/views/live.json
@@ -2,8 +2,8 @@
"documentTitle": "Live - Frigate",
"documentTitle.withCamera": "{{camera}} - Live - Frigate",
"twoWayTalk": {
- "enable": "Aktivera Two Way Talk",
- "disable": "Avaktivera Two Way Talk"
+ "enable": "Aktivera tvåvägssamtal",
+ "disable": "Avaktivera tvåvägssamtal"
},
"cameraAudio": {
"disable": "Inaktivera kameraljud",
@@ -42,7 +42,15 @@
"label": "Klicka i bilden för att centrera PTZ kamera"
}
},
- "presets": "PTZ kamera förinställningar"
+ "presets": "PTZ kamera förinställningar",
+ "focus": {
+ "in": {
+ "label": "Fokusera PTZ-kameran in"
+ },
+ "out": {
+ "label": "Fokusera PTZ-kameran ut"
+ }
+ }
},
"streamStats": {
"enable": "Visa videostatistik",
@@ -65,8 +73,8 @@
"disable": "Avaktivera ljudaktivering"
},
"autotracking": {
- "enable": "Aktivera automatisk panorering",
- "disable": "Avaktivera automatisk panorering"
+ "enable": "Aktivera Autospårning",
+ "disable": "Avaktivera Autospårning"
},
"notifications": "Notifikationer",
"audio": "Ljud",
@@ -74,8 +82,8 @@
"manualRecording": {
"failedToEnd": "Misslyckades med att avsluta manuell vid behov-inspelning.",
"started": "Starta manuell inspelning vid behov.",
- "title": "Aktivera inspelning vid behov",
- "tips": "Starta en manuell händelse enligt denna kameras inställningar för inspelningslagring.",
+ "title": "Vid behov",
+ "tips": "Ladda ner en omedelbar ögonblicksbild eller starta en manuell händelse baserat på kamerans inställningar för inspelningslagring.",
"playInBackground": {
"label": "Spela upp i bakgrunden",
"desc": "Strömma vidare när spelaren inte visas."
@@ -98,7 +106,8 @@
"objectDetection": "Objektsdetektering",
"recording": "Inspelning",
"snapshots": "Ögonblicksbilder",
- "autotracking": "Autospårning"
+ "autotracking": "Autospårning",
+ "transcription": "Ljudtranskription"
},
"effectiveRetainMode": {
"modes": {
@@ -128,7 +137,7 @@
"forTime": "Pausa för: "
},
"stream": {
- "title": "Ström (Swedish also use the word Stream)",
+ "title": "Ström",
"audio": {
"tips": {
"title": "Ljud måste skickas ut från din kamera och konfigureras i go2rtc för den här strömmen.",
@@ -150,9 +159,41 @@
"playInBackground": {
"label": "Spela i bakgrunden",
"tips": "Aktivera det här alternativet för att fortsätta strömma när spelaren är dold."
+ },
+ "debug": {
+ "picker": "Strömval är inte tillgängligt i felsökningsläge. Felsökningsvyn använder alltid den ström som tilldelats detekteringsrollen."
}
},
"history": {
"label": "Visa historiskt videomaterial"
+ },
+ "transcription": {
+ "enable": "Aktivera live-ljudtranskription",
+ "disable": "Inaktivera live-ljudtranskription"
+ },
+ "noCameras": {
+ "title": "Inga kameror konfigurerade",
+ "description": "Börja med att ansluta en kamera till Frigate.",
+ "buttonText": "Lägg till kamera",
+ "restricted": {
+ "title": "Inga kameror tillgängliga",
+ "description": "Du har inte behörighet att visa några kameror i den här gruppen."
+ },
+ "default": {
+ "title": "Ingen kamera konfigurerad",
+ "description": "Börja med att ansluta en kamera till Frigate.",
+ "buttonText": "Lägg till kamera"
+ },
+ "group": {
+ "title": "Inga kameror i gruppen",
+ "description": "Kameragruppen har inga tilldelade eller aktiverade kameror.",
+ "buttonText": "Hantera grupper"
+ }
+ },
+ "snapshot": {
+ "takeSnapshot": "Ladda ner omedelbar ögonblicksbild",
+ "noVideoSource": "Ingen videokälla tillgänglig för ögonblicksbilden.",
+ "captureFailed": "Misslyckades med att ta en ögonblicksbild.",
+ "downloadStarted": "Nedladdning av ögonblicksbild har startat."
}
}
diff --git a/web/public/locales/sv/views/recording.json b/web/public/locales/sv/views/recording.json
index 6e9e231a3..b4bfaf2ec 100644
--- a/web/public/locales/sv/views/recording.json
+++ b/web/public/locales/sv/views/recording.json
@@ -1,6 +1,6 @@
{
"export": "Export",
- "filter": "Filter",
+ "filter": "Filtrera",
"calendar": "Kalender",
"filters": "Filter",
"toast": {
diff --git a/web/public/locales/sv/views/search.json b/web/public/locales/sv/views/search.json
index 5fd24ab76..2e9f4e007 100644
--- a/web/public/locales/sv/views/search.json
+++ b/web/public/locales/sv/views/search.json
@@ -43,7 +43,8 @@
"has_clip": "Har klipp",
"has_snapshot": "Har Ögonblicksbild",
"labels": "Etiketter",
- "max_score": "Högsta Poäng"
+ "max_score": "Högsta Poäng",
+ "attributes": "Attribut"
},
"searchType": {
"thumbnail": "Miniatyrbild",
diff --git a/web/public/locales/sv/views/settings.json b/web/public/locales/sv/views/settings.json
index df1de30e0..8f02a3f22 100644
--- a/web/public/locales/sv/views/settings.json
+++ b/web/public/locales/sv/views/settings.json
@@ -2,26 +2,38 @@
"documentTitle": {
"camera": "Kamerainställningar - Frigate",
"default": "Inställningar - Frigate",
- "general": "Allmänna inställningar - Frigate",
+ "general": "Användargränssnitt Inställningar - Frigate",
"authentication": "Autentiseringsinställningar - Frigate",
"classification": "Klassificeringsinställningar - Frigate",
"masksAndZones": "Maskerings- och zonverktyg - Frigate",
"enrichments": "Förbättringsinställningar - Frigate",
"frigatePlus": "Frigate+ Inställningar - Frigate",
- "notifications": "Notifikations Inställningar - Frigate"
+ "notifications": "Notifikations Inställningar - Frigate",
+ "motionTuner": "Rörelse inställning - Frigate",
+ "object": "Felsöka - Frigate",
+ "cameraManagement": "Hantera kameror - Frigate",
+ "cameraReview": "Kameragranskningsinställningar - Frigate"
},
"general": {
- "title": "Allmänna Inställningar",
+ "title": "UI inställningar",
"liveDashboard": {
"automaticLiveView": {
"desc": "Automatiskt byte till kamera där aktivitet registreras. Inaktivering av denna inställning gör att en statisk bild visas i Live Panelen som uppdateras en gång per minut.",
"label": "Automatisk Live Visning"
},
"playAlertVideos": {
- "desc": "Som standard visas varningar på Live Panelen som små loopande klipp. Inaktivera denna inställning för att bara visa en statisk bild av nya varningar på denna enhet/webbläsare.",
- "label": "Spela Varnings Videos"
+ "desc": "Som standard visas varningar på Live panelen som små loopande klipp. Inaktivera denna inställning för att bara visa en statisk bild av nya varningar på denna enhet/webbläsare.",
+ "label": "Spela upp Varnings videor"
},
- "title": "Live Panel"
+ "title": "Live Panel",
+ "displayCameraNames": {
+ "label": "Visa alltid kameranamn",
+ "desc": "Visa alltid kameranamnen i ett chip i instrumentpanelen för livevisning med flera kameror."
+ },
+ "liveFallbackTimeout": {
+ "label": "Live spelare reserv timeout",
+ "desc": "När en kameras högkvalitativa liveström inte är tillgänglig, återgå till lågbandbreddsläge efter så här många sekunder. Standard: 3."
+ }
},
"storedLayouts": {
"title": "Sparade Layouter",
@@ -44,7 +56,8 @@
"firstWeekday": {
"sunday": "Söndag",
"monday": "Måndag",
- "label": "Första Veckodag"
+ "label": "Första Veckodag",
+ "desc": "Den dag då veckorna i översynskalendern börjar."
},
"title": "Kalender"
},
@@ -66,23 +79,1160 @@
"enrichments": {
"unsavedChanges": "Osparade Förbättringsinställningar",
"birdClassification": {
- "title": "Fågel klassificering"
+ "title": "Fågel klassificering",
+ "desc": "Fågelklassificering identifierar kända fåglar med hjälp av en kvantiserad Tensorflow-modell. När en känd fågel känns igen läggs dess vanliga namn till som en underetikett. Denna information inkluderas i användargränssnittet, filter och i aviseringar."
},
- "title": "Förbättringsinställningar"
+ "title": "Förbättringsinställningar",
+ "semanticSearch": {
+ "title": "Semantisk sökning",
+ "desc": "Semantisk sökning i Frigate låter dig hitta spårade objekt i dina granskningsobjekt med hjälp av antingen själva bilden, en användardefinierad textbeskrivning eller en automatiskt genererad.",
+ "readTheDocumentation": "Läs dokumentationen",
+ "reindexNow": {
+ "label": "Omindexera nu",
+ "desc": "Omindexering kommer att generera inbäddningar för alla spårade objekt. Den här processen körs i bakgrunden och kan maximera din CPU och ta en hel del tid beroende på antalet spårade objekt du har.",
+ "confirmTitle": "Bekräfta omindexering",
+ "confirmDesc": "Är du säker på att du vill omindexera alla spårade objektinbäddningar? Den här processen körs i bakgrunden men den kan maximera din processor och ta en hel del tid. Du kan se förloppet på Utforska-sidan.",
+ "confirmButton": "Omindexera",
+ "success": "Omindexeringen har startat.",
+ "alreadyInProgress": "Omindexering pågår redan.",
+ "error": "Misslyckades med att starta omindexering: {{errorMessage}}"
+ },
+ "modelSize": {
+ "label": "Modellstorlek",
+ "desc": "Storleken på modellen som används för semantiska sökinbäddningar.",
+ "small": {
+ "title": "små",
+ "desc": "Att använda small använder en kvantiserad version av modellen som använder mindre RAM och körs snabbare på CPU med en mycket försumbar skillnad i inbäddningskvalitet."
+ },
+ "large": {
+ "title": "stor",
+ "desc": "Att använda large använder hela Jina-modellen och körs automatiskt på GPU:n om tillämpligt."
+ }
+ }
+ },
+ "faceRecognition": {
+ "desc": "Ansiktsigenkänning gör att personer kan tilldelas namn och när deras ansikte känns igen kommer Frigate att tilldela personens namn som en underetikett. Denna information finns i användargränssnittet, filter och i aviseringar.",
+ "readTheDocumentation": "Läs dokumentationen",
+ "modelSize": {
+ "label": "Modellstorlek",
+ "desc": "Storleken på modellen som används för ansiktsigenkänning.",
+ "small": {
+ "title": "små",
+ "desc": "Att använda small använder en FaceNet-modell för ansiktsinbäddning som körs effektivt på de flesta processorer."
+ },
+ "large": {
+ "title": "stor",
+ "desc": "Att använda large använder en ArcFace-modell för ansiktsinbäddning och körs automatiskt på GPU:n om tillämpligt."
+ }
+ },
+ "title": "Ansikts igenkänning"
+ },
+ "licensePlateRecognition": {
+ "title": "Nummerplåt Erkännande",
+ "desc": "Frigate kan känna igen nummerplåt på fordon och automatiskt lägga till de upptäckta tecknen i fältet recognized_license_plate eller ett känt namn som en underetikett till objekt av typen bil. Ett vanligt användningsfall kan vara att läsa nummerplåtor på bilar som kör in på en uppfart eller bilar som passerar på en gata.",
+ "readTheDocumentation": "Läs dokumentationen"
+ },
+ "restart_required": "Omstart krävs (berikningsinställningar har ändrats)",
+ "toast": {
+ "success": "Inställningarna för berikning har sparats. Starta om Frigate för att tillämpa dina ändringar.",
+ "error": "Kunde inte spara konfigurationsändringarna: {{errorMessage}}"
+ }
},
"menu": {
- "ui": "UI",
+ "ui": "Användargränssnitt",
"cameras": "Kamera Inställningar",
"masksAndZones": "Masker / Områden",
"users": "Användare",
"notifications": "Notifikationer",
"frigateplus": "Frigate+",
- "enrichments": "Förbättringar"
+ "enrichments": "Förbättringar",
+ "motionTuner": "Rörelsemottagare",
+ "debug": "Felsök",
+ "triggers": "Utlösare",
+ "roles": "Roller",
+ "cameraManagement": "Hantering",
+ "cameraReview": "Granska"
},
"dialog": {
"unsavedChanges": {
"title": "Du har osparade ändringar.",
"desc": "Vill du spara dina ändringar innan du fortsätter?"
}
+ },
+ "camera": {
+ "title": "Kamera inställningar",
+ "streams": {
+ "title": "Videoströmmar",
+ "desc": "Inaktivera tillfälligt en kamera tills Frigate startar om. Om du inaktiverar en kamera helt stoppas Frigates bearbetning av kamerans strömmar. Detektering, inspelning och felsökning kommer inte att vara tillgängliga.
Obs! Detta inaktiverar inte go2rtc-återströmmar."
+ },
+ "object_descriptions": {
+ "title": "Generativa AI-objektbeskrivningar",
+ "desc": "Aktivera/inaktivera tillfälligt generativa AI-objektbeskrivningar för den här kameran. När den är inaktiverad kommer AI-genererade beskrivningar inte att begäras för spårade objekt på den här kameran."
+ },
+ "review_descriptions": {
+ "title": "Beskrivningar av generativa AI-granskningar",
+ "desc": "Aktivera/inaktivera tillfälligt genererade AI-granskningsbeskrivningar för den här kameran. När det är inaktiverat kommer AI-genererade beskrivningar inte att begäras för granskningsobjekt på den här kameran."
+ },
+ "review": {
+ "title": "Recensera",
+ "desc": "Tillfälligt Aktivera/avaktivera varningar och detekteringar för den här kameran tills Frigate startar om. När den är avaktiverad genereras inga nya granskningsobjekt. ",
+ "alerts": "Aviseringar ",
+ "detections": "Detektioner "
+ },
+ "reviewClassification": {
+ "title": "Granska klassificering",
+ "desc": "Frigate kategoriserar granskningsobjekt som varningar och detekteringar. Som standard betraktas alla person- och bil-objekt som varningar. Du kan förfina kategoriseringen av dina granskningsobjekt genom att konfigurera obligatoriska zoner för dem.",
+ "noDefinedZones": "Inga zoner är definierade för den här kameran.",
+ "objectAlertsTips": "Alla {{alertsLabels}}-objekt på {{cameraName}} kommer att visas som varningar.",
+ "zoneObjectAlertsTips": "Alla {{alertsLabels}} objekt som upptäcks i {{zone}} på {{cameraName}} kommer att visas som varningar.",
+ "objectDetectionsTips": "Alla {{detectionsLabels}}-objekt som inte kategoriseras på {{cameraName}} kommer att visas som detektioner oavsett vilken zon de befinner sig i.",
+ "zoneObjectDetectionsTips": {
+ "text": "Alla {{detectionsLabels}}-objekt som inte kategoriseras i {{zone}} på {{cameraName}} kommer att visas som detektioner.",
+ "notSelectDetections": "Alla {{detectionsLabels}} objekt som upptäckts i {{zone}} på {{cameraName}} och som inte kategoriserats som varningar kommer att visas som detekteringar oavsett vilken zon de befinner sig i.",
+ "regardlessOfZoneObjectDetectionsTips": "Alla {{detectionsLabels}}-objekt som inte kategoriseras på {{cameraName}} kommer att visas som detektioner oavsett vilken zon de befinner sig i."
+ },
+ "unsavedChanges": "Osparade inställningar för granskningsklassificering för {{camera}}",
+ "selectAlertsZones": "Välj zoner för aviseringar",
+ "selectDetectionsZones": "Välj zoner för detektioner",
+ "limitDetections": "Begränsa detektioner till specifika zoner",
+ "toast": {
+ "success": "Konfigurationen för granskning av klassificering har sparats. Starta om Frigate för att tillämpa ändringarna."
+ }
+ },
+ "addCamera": "Lägg till ny kamera",
+ "editCamera": "Redigera kamera:",
+ "selectCamera": "Välj en kamera",
+ "backToSettings": "Tillbaka till kamera inställningar",
+ "cameraConfig": {
+ "add": "Lägg till kamera",
+ "edit": "Redigera kamera",
+ "description": "Konfigurera kamerainställningar inklusive strömingångar och roller.",
+ "name": "Kamera namn",
+ "nameRequired": "Kamera namn krävs",
+ "nameInvalid": "Kamera namnet får endast innehålla bokstäver, siffror, understreck, eller bindestreck",
+ "namePlaceholder": "t.ex. fram_dörr",
+ "enabled": "Aktiverad",
+ "ffmpeg": {
+ "inputs": "Ingångsströmmar",
+ "path": "Strömväg",
+ "pathRequired": "Strömningsväg krävs",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Roller",
+ "rolesRequired": "Minst en roll krävs",
+ "rolesUnique": "Varje roll (ljud, detektering, inspelning) kan bara tilldelas en ström",
+ "addInput": "Lägg till inmatningsström",
+ "removeInput": "Ta bort inmatningsström",
+ "inputsRequired": "Minst en indataström krävs"
+ },
+ "toast": {
+ "success": "Kamera {{cameraName}} sparades"
+ },
+ "nameLength": "Namnet på kameran måste vara kortare än 24 tecken."
+ }
+ },
+ "masksAndZones": {
+ "filter": {
+ "all": "Alla masker och zoner"
+ },
+ "restart_required": "Omstart krävs (masker/zoner har ändrats)",
+ "toast": {
+ "success": {
+ "copyCoordinates": "Kopierade koordinaterna för {{polyName}} till urklipp."
+ },
+ "error": {
+ "copyCoordinatesFailed": "Kunde inte kopiera koordinaterna till urklipp."
+ }
+ },
+ "motionMaskLabel": "Rörelsemask {{number}}",
+ "objectMaskLabel": "Objektmask {{number}} ({{label}})",
+ "form": {
+ "zoneName": {
+ "error": {
+ "mustBeAtLeastTwoCharacters": "Zonnamnet måste vara minst 2 tecken långt.",
+ "mustNotBeSameWithCamera": "Zonnamnet får inte vara detsamma som kameranamnet.",
+ "alreadyExists": "En zon med detta namn finns redan för den här kameran.",
+ "mustNotContainPeriod": "Zonnamnet får inte innehålla punkter.",
+ "hasIllegalCharacter": "Zonnamnet innehåller ogiltiga tecken.",
+ "mustHaveAtLeastOneLetter": "Zonnamnet måste ha minst en bokstav."
+ }
+ },
+ "distance": {
+ "error": {
+ "text": "Avståndet måste vara större än eller lika med 0,1.",
+ "mustBeFilled": "Alla avståndsfält måste fyllas i för att hastighetsuppskattning ska kunna användas."
+ }
+ },
+ "inertia": {
+ "error": {
+ "mustBeAboveZero": "Trögheten måste vara över 0."
+ }
+ },
+ "loiteringTime": {
+ "error": {
+ "mustBeGreaterOrEqualZero": "Uppehållstiden måste vara större än eller lika med 0."
+ }
+ },
+ "speed": {
+ "error": {
+ "mustBeGreaterOrEqualTo": "Gränsvärdet för hastigheten måste vara större eller lika med 0.1."
+ }
+ },
+ "polygonDrawing": {
+ "removeLastPoint": "Ta bort senaste punkten",
+ "reset": {
+ "label": "Rensa alla punkter"
+ },
+ "snapPoints": {
+ "true": "Fäst punkter",
+ "false": "Fäst inte punkter"
+ },
+ "delete": {
+ "title": "Bekräfta borttagning",
+ "desc": "Är du säker på att du vill ta bort {{type}} {{name}}?",
+ "success": "{{name}} har raderats."
+ },
+ "error": {
+ "mustBeFinished": "Polygonritningen måste vara klar innan du sparar."
+ }
+ }
+ },
+ "zones": {
+ "label": "Zoner",
+ "documentTitle": "Redigera zon - Frigate",
+ "desc": {
+ "documentation": "Dokumentation",
+ "title": "Zoner låter dig definiera ett specifikt område av bilden så att du kan avgöra om ett objekt befinner sig inom ett visst område eller inte."
+ },
+ "add": "Lägg till zon",
+ "edit": "Redigera zon",
+ "name": {
+ "title": "Namn",
+ "inputPlaceHolder": "Ange ett namn…",
+ "tips": "Namnet måste vara minst 2 tecken långt, måste innehålla minst en bokstav och får inte vara namnet på en kamera eller någon annan zon på den här kameran."
+ },
+ "inertia": {
+ "title": "Momentum",
+ "desc": "Anger hur många bildrutor ett objekt måste finnas i en zon innan de räknas som en del av zonen. Standard: 3"
+ },
+ "objects": {
+ "title": "Objekt",
+ "desc": "Lista över objekt som gäller för den här zonen."
+ },
+ "allObjects": "Alla objekt",
+ "point_one": "{{count}} poäng",
+ "point_other": "{{count}} poäng",
+ "clickDrawPolygon": "Klicka för att rita en polygon på bilden.",
+ "loiteringTime": {
+ "title": "Tid någon hänger omkring",
+ "desc": "Ställer in en minsta tid i sekunder som objektet måste vara i zonen för att det ska aktiveras. Standard: 0"
+ },
+ "speedEstimation": {
+ "title": "Hastighetsuppskattning",
+ "desc": "Aktivera hastighetsuppskattning för objekt i den här zonen. Zonen måste ha exakt fyra punkter.",
+ "lineADistance": "Avstånd till linje A ({{unit}})",
+ "lineBDistance": "Avstånd till linje B ({{unit}})",
+ "lineCDistance": "Avstånd till linje C ({{unit}})",
+ "lineDDistance": "Avstånd till linje D ({{unit}})"
+ },
+ "speedThreshold": {
+ "title": "Hastighetsgräns ({{unit}})",
+ "desc": "Anger en lägsta hastighet för objekt som ska beaktas i denna zon.",
+ "toast": {
+ "error": {
+ "pointLengthError": "Hastighetsuppskattning har inaktiverats för den här zonen. Zoner med hastighetsuppskattning måste ha exakt 4 punkter.",
+ "loiteringTimeError": "Zoner med uppehållstider större än 0 bör inte användas vid hastighetsuppskattning."
+ }
+ }
+ },
+ "toast": {
+ "success": "Zonen ({{zoneName}}) har sparats."
+ }
+ },
+ "motionMasks": {
+ "label": "Rörelsemask",
+ "documentTitle": "Redigera rörelsemask - Frigate",
+ "desc": {
+ "title": "Rörelsemasker används för att förhindra att oönskade typer av rörelser utlöser detektering. Övermaskering gör det svårare att spåra objekt.",
+ "documentation": "Dokumentation"
+ },
+ "add": "Ny rörelsemask",
+ "edit": "Redigera rörelsemask",
+ "context": {
+ "title": "Rörelsemasker används för att förhindra att oönskade typer av rörelser utlöser detektering (till exempel: trädgrenar, kameratidsstämplar). Rörelsemasker bör användas mycket sparsamt, övermaskering gör det svårare att spåra objekt."
+ },
+ "point_one": "{{count}} poäng",
+ "point_other": "{{count}} poäng",
+ "clickDrawPolygon": "Klicka för att rita en polygon på bilden.",
+ "polygonAreaTooLarge": {
+ "title": "Rörelsemasken täcker {{polygonArea}}% av kamerabilden. Stora rörelsemasker rekommenderas inte.",
+ "tips": "Rörelsemasker förhindrar inte att objekt upptäcks. Du bör använda en obligatorisk zon istället."
+ },
+ "toast": {
+ "success": {
+ "title": "{{polygonName}} har sparats.",
+ "noName": "Rörelsemasken har sparats."
+ }
+ }
+ },
+ "objectMasks": {
+ "label": "Objektmasker",
+ "documentTitle": "Redigera objektmask - Frigate",
+ "point_one": "{{count}} poäng",
+ "point_other": "{{count}} poäng",
+ "desc": {
+ "title": "Objektfiltermasker används för att filtrera bort falska positiva resultat för en given objekttyp baserat på plats.",
+ "documentation": "Dokumentation"
+ },
+ "add": "Lägg till objektmask",
+ "edit": "Redigera objektmask",
+ "context": "Objektfiltermasker används för att filtrera bort falska positiva resultat för en given objekttyp baserat på plats.",
+ "clickDrawPolygon": "Klicka för att rita en polygon på bilden.",
+ "objects": {
+ "title": "Objekt",
+ "desc": "Objekttypen som gäller för den här objektmasken.",
+ "allObjectTypes": "Alla objekttyper"
+ },
+ "toast": {
+ "success": {
+ "title": "{{polygonName}} har sparats.",
+ "noName": "Objektmasken har sparats."
+ }
+ }
+ }
+ },
+ "motionDetectionTuner": {
+ "title": "Rörelsedetekteringstuner",
+ "unsavedChanges": "Osparade ändringar i Motion Tuner ({{camera}})",
+ "desc": {
+ "title": "Frigate använder rörelsedetektering som en första kontroll för att se om det händer något i bilden som är värt att kontrollera med objektdetektering.",
+ "documentation": "Läs guiden för rörelsejustering"
+ },
+ "Threshold": {
+ "title": "Tröskel",
+ "desc": "Tröskelvärdet anger hur mycket förändring i en pixels luminans som krävs för att betraktas som rörelse. Standard: 30"
+ },
+ "contourArea": {
+ "title": "Konturområde",
+ "desc": "Konturareans värde används för att avgöra vilka grupper av ändrade pixlar som kvalificeras som rörelse. Standard: 10"
+ },
+ "improveContrast": {
+ "title": "Förbättra kontrasten",
+ "desc": "Förbättra kontrasten för mörkare scener. Standard: PÅ"
+ },
+ "toast": {
+ "success": "Rörelseinställningarna har sparats."
+ }
+ },
+ "debug": {
+ "title": "Felsök",
+ "detectorDesc": "Fregate använder dina detektorer ({{detectors}}) för att upptäcka objekt i din kameras videoström.",
+ "desc": "Felsökningsvyn visar en realtidsvy av spårade objekt och deras statistik. Objektlistan visar en tidsfördröjd sammanfattning av upptäckta objekt.",
+ "openCameraWebUI": "Öppna {{camera}}s webbgränssnitt",
+ "debugging": "Felsökning",
+ "objectList": "Objektlista",
+ "noObjects": "Inga föremål",
+ "audio": {
+ "title": "Ljud",
+ "noAudioDetections": "Inga ljuddetekteringar",
+ "score": "betyg",
+ "currentRMS": "Nuvarande RMS",
+ "currentdbFS": "Nuvarande dbFS"
+ },
+ "boundingBoxes": {
+ "title": "Avgränsande rutor",
+ "desc": "Visa avgränsningsrutor runt spårade objekt",
+ "colors": {
+ "label": "Färger för objektgränser",
+ "info": "Vid uppstart tilldelas olika färger till varje objektetikett En mörkblå tunn linje indikerar att objektet inte detekteras vid denna aktuella tidpunkt En grå tunn linje indikerar att objektet detekteras som stillastående En tjock linje indikerar att objektet är föremål för autospårning (när det är aktiverat) "
+ }
+ },
+ "timestamp": {
+ "title": "Tidsstämpel",
+ "desc": "Lägg en tidsstämpel över bilden"
+ },
+ "zones": {
+ "title": "Zoner",
+ "desc": "Visa en översikt över alla definierade zoner"
+ },
+ "mask": {
+ "title": "Rörelsemasker",
+ "desc": "Visa rörelsemaskpolygoner"
+ },
+ "motion": {
+ "title": "Rörelseboxar",
+ "desc": "Visa rutor runt områden där rörelse detekteras",
+ "tips": "Rörelserutor
Röda rutor kommer att läggas över områden i bilden där rörelse för närvarande detekteras
"
+ },
+ "regions": {
+ "title": "Regioner",
+ "desc": "Visa en ruta med det intresseområde som skickats till objektdetektorn",
+ "tips": "Regionsrutor
Ljusgröna rutor kommer att läggas över intressanta områden i bilden som skickas till objektdetektorn.
"
+ },
+ "paths": {
+ "title": "Vägar",
+ "desc": "Visa viktiga punkter i det spårade objektets bana",
+ "tips": "Vägar
Linjer och cirklar indikerar viktiga punkter som det spårade objektet har flyttat under sin livscykel.
"
+ },
+ "objectShapeFilterDrawing": {
+ "title": "Ritning av objektformfilter",
+ "desc": "Rita en rektangel på bilden för att visa detaljer om area och förhållande",
+ "tips": "Aktivera det här alternativet för att rita en rektangel på kamerabilden för att visa dess area och förhållande. Dessa värden kan sedan användas för att ställa in parametrar för objektformsfilter i din konfiguration.",
+ "score": "Betyg",
+ "ratio": "Förhållandet",
+ "area": "Område"
+ }
+ },
+ "users": {
+ "title": "Användare",
+ "management": {
+ "title": "Användarhantering",
+ "desc": "Hantera användarkonton för denna Frigate-instans."
+ },
+ "addUser": "Lägg till användare",
+ "updatePassword": "Återställ lösenord",
+ "toast": {
+ "success": {
+ "createUser": "Användaren {{user}} har skapats",
+ "deleteUser": "Användaren {{user}} har raderats",
+ "updatePassword": "Lösenordet har uppdaterats.",
+ "roleUpdated": "Rollen uppdaterades för {{user}}"
+ },
+ "error": {
+ "setPasswordFailed": "Misslyckades med att spara lösenordet: {{errorMessage}}",
+ "createUserFailed": "Misslyckades med att skapa användare: {{errorMessage}}",
+ "deleteUserFailed": "Misslyckades med att ta bort användaren: {{errorMessage}}",
+ "roleUpdateFailed": "Misslyckades med att uppdatera rollen: {{errorMessage}}"
+ }
+ },
+ "table": {
+ "username": "Användarnamn",
+ "actions": "Åtgärder",
+ "role": "Roll",
+ "noUsers": "Inga användare hittades.",
+ "changeRole": "Ändra användarroll",
+ "password": "Återställ Lösenord",
+ "deleteUser": "Ta bort användare"
+ },
+ "dialog": {
+ "form": {
+ "user": {
+ "title": "Användarnamn",
+ "desc": "Endast bokstäver, siffror, punkter och understreck är tillåtna.",
+ "placeholder": "Ange användarnamn"
+ },
+ "password": {
+ "title": "Lösenord",
+ "strength": {
+ "title": "Lösenordsstyrka: ",
+ "weak": "Svag",
+ "medium": "Mellanstark",
+ "strong": "Stark",
+ "veryStrong": "Mycket stark"
+ },
+ "match": "Lösenorden matchar",
+ "notMatch": "Lösenorden matchar inte",
+ "placeholder": "Ange lösenord",
+ "confirm": {
+ "title": "Bekräfta lösenord",
+ "placeholder": "Bekräfta lösenord"
+ },
+ "show": "Visa lösenord",
+ "hide": "Dölj lösenord",
+ "requirements": {
+ "title": "Lösenordskrav:",
+ "length": "Minst 12 tecken",
+ "uppercase": "Minst en stor bokstav",
+ "digit": "Minst en siffra",
+ "special": "Minst ett specialtecken (!@#$%^&*(),.?\":{}|<>)"
+ }
+ },
+ "newPassword": {
+ "title": "Nytt lösenord",
+ "placeholder": "Ange nytt lösenord",
+ "confirm": {
+ "placeholder": "Ange nytt lösenord igen"
+ }
+ },
+ "usernameIsRequired": "Användarnamn krävs",
+ "passwordIsRequired": "Lösenord krävs",
+ "currentPassword": {
+ "title": "Nuvarande lösenord",
+ "placeholder": "Ange ditt nuvarande lösenord"
+ }
+ },
+ "createUser": {
+ "title": "Skapa ny användare",
+ "desc": "Lägg till ett nytt användarkonto och ange en roll för åtkomst till områden i Frigate gränssnittet.",
+ "usernameOnlyInclude": "Användarnamnet får endast innehålla bokstäver, siffror, . eller _",
+ "confirmPassword": "Vänligen bekräfta ditt lösenord"
+ },
+ "deleteUser": {
+ "title": "Ta bort användare",
+ "desc": "Den här åtgärden kan inte ångras. Detta kommer att permanent radera användarkontot och all tillhörande data.",
+ "warn": "Är du säker på att du vill ta bort {{username}}?"
+ },
+ "passwordSetting": {
+ "cannotBeEmpty": "Lösenordet får inte vara tomt",
+ "doNotMatch": "Lösenorden matchar inte",
+ "updatePassword": "Uppdatera lösenord för {{username}}",
+ "setPassword": "Ange lösenord",
+ "desc": "Skapa ett starkt lösenord för att säkra det här kontot.",
+ "currentPasswordRequired": "Nuvarande lösenord krävs",
+ "incorrectCurrentPassword": "Nuvarande lösenord är felaktigt",
+ "passwordVerificationFailed": "Misslyckades med att verifiera lösenordet",
+ "multiDeviceWarning": "Alla andra enheter där du är inloggad måste logga in igen inom {{refresh_time}}.",
+ "multiDeviceAdmin": "Du kan också tvinga alla användare att autentisera om sig omedelbart genom att rotera din JWT-hemlighet."
+ },
+ "changeRole": {
+ "title": "Ändra användarroll",
+ "select": "Välj en roll",
+ "desc": "Uppdatera behörigheter för {{username}}",
+ "roleInfo": {
+ "intro": "Välj lämplig roll för den här användaren:",
+ "admin": "Administratör",
+ "adminDesc": "Full åtkomst till alla funktioner.",
+ "viewer": "Åskådare",
+ "viewerDesc": "Begränsat till Live-dashboards, Review, Explore, och Exports bara.",
+ "customDesc": "Anpassad roll med specifik kameraåtkomst."
+ }
+ }
+ }
+ },
+ "notification": {
+ "title": "Aviseringar",
+ "notificationSettings": {
+ "title": "Aviseringsinställningar",
+ "desc": "Frigate kan skicka push-notiser till din enhet när den körs i webbläsare eller installerad som PWA."
+ },
+ "globalSettings": {
+ "title": "Övergripande inställningar",
+ "desc": "Stäng tillfälligt av aviseringar för specifika kameror på alla registrerade enheter."
+ },
+ "email": {
+ "title": "E-post",
+ "placeholder": "t.ex. exempel@epost.se",
+ "desc": "En giltig e-postadress krävs och kommer att användas för att meddela dig om det uppstår problem med push-tjänsten."
+ },
+ "cameras": {
+ "title": "Kameror",
+ "noCameras": "Inga kameror tillgängliga",
+ "desc": "Välj vilka kameror som notifikationer ska aktiveras för."
+ },
+ "unregisterDevice": "Avregistrera enheten",
+ "sendTestNotification": "Skicka testnotis",
+ "active": "Aviseringar är aktiva",
+ "notificationUnavailable": {
+ "title": "Meddelanden otillgängliga",
+ "desc": "Webb push-meddelanden kräver en säker kontext (https://…). Detta är en begränsning i webbläsaren. Få säker åtkomst till Frigate för att använda meddelanden."
+ },
+ "deviceSpecific": "Enhetsspecifika inställningar",
+ "registerDevice": "Registrera den här enheten",
+ "unsavedRegistrations": "Osparade aviseringsregistreringar",
+ "unsavedChanges": "Osparade ändringar till aviseringar",
+ "suspended": "Aviseringar avstängda {{time}}",
+ "suspendTime": {
+ "suspend": "Pausa",
+ "5minutes": "Pausa i 5 minuter",
+ "10minutes": "Pausa i 10 minuter",
+ "30minutes": "Pausa i 30 minuter",
+ "1hour": "Pausa i 1 timme",
+ "12hours": "Pausa i 12 timmar",
+ "24hours": "Pausa i 24 timmar",
+ "untilRestart": "Pausa tills omstart"
+ },
+ "cancelSuspension": "Avbryt pausning",
+ "toast": {
+ "success": {
+ "registered": "Registreringen för aviseringar har lyckats. Omstart av Frigate krävs innan några aviseringar (inklusive en testavisering) kan skickas.",
+ "settingSaved": "Aviseringsinställningarna har sparats."
+ },
+ "error": {
+ "registerFailed": "Det gick inte att spara aviseringsregistreringen."
+ }
+ }
+ },
+ "roles": {
+ "addRole": "Lägg till roll",
+ "table": {
+ "role": "Roll",
+ "cameras": "Kameror",
+ "noRoles": "Inga anpassade roller hittades.",
+ "editCameras": "Redigera kameror",
+ "deleteRole": "Radera roll",
+ "actions": "Åtgärder"
+ },
+ "toast": {
+ "success": {
+ "createRole": "Roll {{role}} skapad",
+ "updateCameras": "Kameror uppdaterade för roll {{role}}",
+ "deleteRole": "Roll {{role}} raderad",
+ "userRolesUpdated_one": "{{count}} användare som tilldelats den här rollen har uppdaterats till 'tittare', vilket har åtkomst till alla kameror.",
+ "userRolesUpdated_other": "{{count}} användare som tilldelats den här rollen har uppdaterats till 'tittare', vilket har åtkomst till alla kameror."
+ },
+ "error": {
+ "createRoleFailed": "Misslyckades att skapa roll: {{errorMessage}}",
+ "updateCamerasFailed": "Misslyckades att uppdatera kameror: {{errorMessage}}",
+ "deleteRoleFailed": "Misslyckades att radera roll: {{errorMessage}}",
+ "userUpdateFailed": "Misslyckades att uppdatera användar-roller: {{errorMessage}}"
+ }
+ },
+ "dialog": {
+ "createRole": {
+ "title": "Skapa ny roll",
+ "desc": "Skapa en ny roll och ange kamera åtkomstbehörigheter."
+ },
+ "deleteRole": {
+ "title": "Radera roll",
+ "deleting": "Raderar...",
+ "desc": "Den här åtgärden kan inte ångras. Detta kommer att ta bort rollen permanent och tilldela alla användare med rollen 'tittare', vilket ger tittaren åtkomst till alla kameror.",
+ "warn": "Är du säker på att du vill ta bort {{role}}?"
+ },
+ "form": {
+ "role": {
+ "placeholder": "Ange rollens namn",
+ "desc": "Enbart bokstäver, siffror, punkter och understreck tillåtna.",
+ "roleIsRequired": "Rollens namn krävs",
+ "roleExists": "En roll med detta namn finns redan.",
+ "title": "Rollnamn",
+ "roleOnlyInclude": "Rollnamnet får endast innehålla bokstäver, siffror, . eller _"
+ },
+ "cameras": {
+ "title": "Kameror",
+ "required": "Minst en kamera måste väljas.",
+ "desc": "Välj kameror som den här rollen har åtkomst till. Minst en kamera krävs."
+ }
+ },
+ "editCameras": {
+ "title": "Redigera rollkameror",
+ "desc": "Uppdatera kameraåtkomst för rollen {{role}}."
+ }
+ },
+ "management": {
+ "title": "Hantering av tittarroller",
+ "desc": "Hantera anpassade tittarroller och deras kameraåtkomstbehörigheter för den här Frigate instansen."
+ }
+ },
+ "frigatePlus": {
+ "title": "Frigate+ Inställningar",
+ "apiKey": {
+ "notValidated": "Frigate+ API-nyckeln upptäcktes inte eller validerades inte",
+ "desc": "Frigate+ API-nyckeln möjliggör integration med Frigate+-tjänsten.",
+ "plusLink": "Läs mer om Frigate+",
+ "title": "Frigate+ API-nyckel",
+ "validated": "Frigate+ API-nyckeln har upptäckts och validerats"
+ },
+ "snapshotConfig": {
+ "title": "Ögonblicksbild konfiguration",
+ "desc": "Att skicka till Frigate+ kräver att både snapshots och clean_copy snapshots är aktiverade i din konfiguration.",
+ "cleanCopyWarning": "Vissa kameror har aktiverade ögonblicksbilder men har ren kopia inaktiverad. Du måste aktivera clean_copy i din ögonblicksbild konfiguration för att kunna skicka bilder från dessa kameror till Frigate+.",
+ "table": {
+ "camera": "Kamera",
+ "snapshots": "Ögonblicksbilder",
+ "cleanCopySnapshots": "clean_copy Ögonblicksbilder"
+ }
+ },
+ "modelInfo": {
+ "title": "Modellinformation",
+ "modelType": "Modelltyp",
+ "trainDate": "Träningsdatum",
+ "baseModel": "Basmodell",
+ "plusModelType": {
+ "baseModel": "Basmodell",
+ "userModel": "Finjusterad"
+ },
+ "supportedDetectors": "Detektorer som stöds",
+ "cameras": "Kameror",
+ "loading": "Laddar modellinformation…",
+ "error": "Misslyckades med att ladda modellinformationen",
+ "availableModels": "Tillgängliga modeller",
+ "loadingAvailableModels": "Laddar tillgängliga modeller…",
+ "modelSelect": "Dina tillgängliga modeller på Frigate+ kan väljas här. Observera att endast modeller som är kompatibla med din nuvarande detektorkonfiguration kan väljas."
+ },
+ "unsavedChanges": "Osparade ändringar av inställningar för Frigate+",
+ "restart_required": "Omstart krävs (Frigate+ modell ändrad)",
+ "toast": {
+ "success": "Inställningarna för Frigate+ har sparats. Starta om Frigate för att tillämpa ändringarna.",
+ "error": "Kunde inte spara konfigurationsändringarna: {{errorMessage}}"
+ }
+ },
+ "triggers": {
+ "documentTitle": "Utlösare",
+ "management": {
+ "title": "Utlösare",
+ "desc": "Hantera utlösare för {{camera}}. Använd miniatyrtypen för att utlösa liknande miniatyrer som ditt valda spårade objekt och beskrivningstypen för att utlösa liknande beskrivningar av text du anger."
+ },
+ "addTrigger": "Lägg till utlösare",
+ "table": {
+ "name": "Namn",
+ "type": "Typ",
+ "content": "Innehåll",
+ "threshold": "Tröskel",
+ "actions": "Åtgärder",
+ "noTriggers": "Inga utlösare konfigurerade för den här kameran.",
+ "edit": "Redigera",
+ "deleteTrigger": "Ta bort utlösare",
+ "lastTriggered": "Senast utlöst"
+ },
+ "type": {
+ "thumbnail": "Miniatyrbild",
+ "description": "Beskrivning"
+ },
+ "actions": {
+ "notification": "Skicka avisering",
+ "alert": "Markera som Varning",
+ "sub_label": "Lägg till underetikett",
+ "attribute": "Lägg till attribut"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "Skapa utlösare",
+ "desc": "Skapa en utlösare för kamera {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Redigera utlösare",
+ "desc": "Redigera inställningarna för utlösare på kameran {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Ta bort utlösare",
+ "desc": "Är du säker på att du vill ta bort utlösaren {{triggerName}}? Den här åtgärden kan inte ångras."
+ },
+ "form": {
+ "name": {
+ "title": "Namn",
+ "placeholder": "Namnge denna utlösare",
+ "error": {
+ "minLength": "Fältet måste vara minst 2 tecken långt.",
+ "invalidCharacters": "Fältet får bara innehålla bokstäver, siffror, understreck och bindestreck.",
+ "alreadyExists": "En utlösare med detta namn finns redan för den här kameran."
+ },
+ "description": "Ange ett unikt namn eller en unik beskrivning för att identifiera den här utlösaren"
+ },
+ "enabled": {
+ "description": "Aktivera eller inaktivera den här utlösaren"
+ },
+ "type": {
+ "title": "Typ",
+ "placeholder": "Välj utlösartyp",
+ "description": "Utlöses när en liknande beskrivning av spårat objekt detekteras",
+ "thumbnail": "Utlöses när en liknande miniatyrbild av ett spårat objekt upptäcks"
+ },
+ "content": {
+ "title": "Innehåll",
+ "imagePlaceholder": "Välj en miniatyrbild",
+ "textPlaceholder": "Ange textinnehåll",
+ "imageDesc": "Endast de senaste 100 miniatyrerna visas. Om du inte hittar önskad miniatyr kan du granska tidigare objekt i Utforska och skapa en utlösare från menyn där.",
+ "textDesc": "Ange text för att utlösa den här åtgärden när en liknande beskrivning av spårat objekt upptäcks.",
+ "error": {
+ "required": "Innehåll krävs."
+ }
+ },
+ "threshold": {
+ "title": "Tröskel",
+ "error": {
+ "min": "Tröskelvärdet måste vara minst 0",
+ "max": "Tröskelvärdet får vara högst 1"
+ },
+ "desc": "Ställ in likhetströskeln för denna utlösare. En högre tröskel innebär att en bättre matchning krävs för att utlösaren ska aktiveras."
+ },
+ "actions": {
+ "title": "Åtgärder",
+ "desc": "Som standard utlöser Frigate ett MQTT-meddelande för alla utlösare. Underetiketter lägger till utlösarnamnet till objektetiketten. Attribut är sökbara metadata som lagras separat i de spårade objektmetadata.",
+ "error": {
+ "min": "Minst en åtgärd måste väljas."
+ }
+ },
+ "friendly_name": {
+ "title": "Vänligt namn",
+ "placeholder": "Namnge eller beskriv denna utlösare",
+ "description": "Ett valfritt vänligt namn eller en beskrivande text för denna utlösare."
+ }
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Utlösaren {{name}} har skapats.",
+ "updateTrigger": "Utlösaren {{name}} har uppdaterats.",
+ "deleteTrigger": "Utlösaren {{name}} har raderats."
+ },
+ "error": {
+ "createTriggerFailed": "Misslyckades med att skapa utlösaren: {{errorMessage}}",
+ "updateTriggerFailed": "Misslyckades med att uppdatera utlösaren: {{errorMessage}}",
+ "deleteTriggerFailed": "Misslyckades med att ta bort utlösaren: {{errorMessage}}"
+ }
+ },
+ "semanticSearch": {
+ "title": "Semantisk sökning är inaktiverad",
+ "desc": "Semantisk sökning måste vara aktiverad för att använda Utlösare."
+ },
+ "wizard": {
+ "title": "Skapa utlösare",
+ "step1": {
+ "description": "Konfigurera grundinställningarna för din trigger."
+ },
+ "step2": {
+ "description": "Ställ in innehållet som ska utlösa den här åtgärden."
+ },
+ "step3": {
+ "description": "Konfigurera tröskelvärdet och åtgärderna för den här utlösaren."
+ },
+ "steps": {
+ "nameAndType": "Namn och typ",
+ "configureData": "Konfigurera data",
+ "thresholdAndActions": "Tröskelvärde och åtgärder"
+ }
+ }
+ },
+ "cameraWizard": {
+ "title": "Lägg till kamera",
+ "description": "Följ stegen nedan för att lägga till en ny kamera i din Frigate-installation.",
+ "steps": {
+ "nameAndConnection": "Namn och anslutning",
+ "streamConfiguration": "Strömkonfiguration",
+ "validationAndTesting": "Validering och testning",
+ "probeOrSnapshot": "Prob eller ögonblicksbild"
+ },
+ "save": {
+ "success": "Ny kamera {{cameraName}} har sparats.",
+ "failure": "Fel vid sparning av {{cameraName}}."
+ },
+ "testResultLabels": {
+ "resolution": "Upplösning",
+ "video": "Video",
+ "audio": "Ljud",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Ange en giltig strömnings länk",
+ "testFailed": "Strömtest misslyckades: {{error}}"
+ },
+ "step1": {
+ "description": "Ange dina kamerauppgifter och välj att undersöka kameran eller manuellt välja märke.",
+ "cameraName": "Kameranamn",
+ "cameraNamePlaceholder": "t.ex. ytterdörr eller Översikt över bakgård",
+ "host": "Värd-/IP-adress",
+ "port": "Portnummer",
+ "username": "Användarnamn",
+ "usernamePlaceholder": "Frivillig",
+ "password": "Lösenord",
+ "passwordPlaceholder": "Frivillig",
+ "selectTransport": "Välj transportprotokoll",
+ "cameraBrand": "Kameramärke",
+ "selectBrand": "Välj kameramärke för URL-mall",
+ "customUrl": "Anpassad ström länk",
+ "brandInformation": "Varumärkesinformation",
+ "brandUrlFormat": "För kameror med RTSP URL-formatet: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://användarnamn:passord@värd:port/text",
+ "testConnection": "Testa anslutning",
+ "testSuccess": "Anslutningstestet lyckades!",
+ "testFailed": "Anslutningstestet misslyckades. Kontrollera dina indata och försök igen.",
+ "streamDetails": "Streamdetaljer",
+ "warnings": {
+ "noSnapshot": "Det gick inte att hämta en ögonblicksbild från den konfigurerade strömmen."
+ },
+ "errors": {
+ "brandOrCustomUrlRequired": "Välj antingen ett kameramärke med värd/IP eller välj \"Annat\" med en anpassad URL",
+ "nameRequired": "Kameranamn krävs",
+ "nameLength": "Kameranamnet måste vara högst 64 tecken långt",
+ "invalidCharacters": "Kameranamnet innehåller ogiltiga tecken",
+ "nameExists": "Kameranamnet finns redan",
+ "brands": {
+ "reolink-rtsp": "Reolink RTSP rekommenderas inte. Aktivera HTTP i kamerans firmwareinställningar och starta om guiden."
+ },
+ "customUrlRtspRequired": "Anpassade webbadresser måste börja med \"rtsp://\". Manuell konfiguration krävs för kameraströmmar som inte använder RTSP."
+ },
+ "docs": {
+ "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras"
+ },
+ "testing": {
+ "probingMetadata": "Undersöker kamerans metadata...",
+ "fetchingSnapshot": "Hämtar kamerabild..."
+ },
+ "connectionSettings": "Anslutningsinställningar",
+ "detectionMethod": "Strömdetekteringsmetod",
+ "onvifPort": "ONVIF-port",
+ "probeMode": "Undersök kameran",
+ "manualMode": "Manuellt val",
+ "detectionMethodDescription": "Undersök kameran med ONVIF (om det stöds) för att hitta kameraströms-URL:er, eller välj kameramärke manuellt för att använda fördefinierade URL:er. För att ange en anpassad RTSP-URL, välj den manuella metoden och välj \"Annat\".",
+ "onvifPortDescription": "För kameror som stöder ONVIF är detta vanligtvis 80 eller 8080.",
+ "useDigestAuth": "Använd digest-autentisering",
+ "useDigestAuthDescription": "Använd HTTP-sammanfattningsautentisering för ONVIF. Vissa kameror kan kräva ett dedikerat ONVIF-användarnamn/lösenord istället för standardadministratörsanvändaren."
+ },
+ "step2": {
+ "description": "Undersök kameran efter tillgängliga strömmar eller konfigurera manuella inställningar baserat på din valda detekteringsmetod.",
+ "streamsTitle": "Kameraströmmar",
+ "addStream": "Lägg till ström",
+ "addAnotherStream": "Lägg till ytterligare en ström",
+ "streamTitle": "Ström {{number}}",
+ "streamUrl": "Ström URL",
+ "streamUrlPlaceholder": "rtsp://användarnamn:lösenord@värd:portnummer/plats",
+ "url": "URL",
+ "resolution": "Upplösning",
+ "selectResolution": "Välj upplösning",
+ "quality": "Kvalitet",
+ "selectQuality": "Välj kvalitet",
+ "roles": "Roller",
+ "roleLabels": {
+ "detect": "Objektdetektering",
+ "record": "Inspelning",
+ "audio": "Ljud"
+ },
+ "testStream": "Testa anslutning",
+ "testSuccess": "Anslutningstestet lyckades!",
+ "testFailed": "Anslutningstestet misslyckades. Kontrollera dina indata och försök igen.",
+ "testFailedTitle": "Testet misslyckades",
+ "connected": "Ansluten",
+ "notConnected": "Inte ansluten",
+ "featuresTitle": "Funktioner",
+ "go2rtc": "Minska anslutningar till kameran",
+ "detectRoleWarning": "Minst en ström måste ha rollen \"upptäcka\" för att fortsätta.",
+ "rolesPopover": {
+ "title": "Ström-roller",
+ "detect": "Huvud video ström för objektdetektering.",
+ "record": "Sparar segment av videoflödet baserat på konfigurationsinställningar.",
+ "audio": "Flöde för ljudbaserad detektering."
+ },
+ "featuresPopover": {
+ "title": "Strömfunktioner",
+ "description": "Använd go2rtc-omströmning för att minska anslutningar till din kamera."
+ },
+ "streamDetails": "Streamdetaljer",
+ "probing": "Undersöker kameran...",
+ "retry": "Försöka igen",
+ "testing": {
+ "probingMetadata": "Undersöker kamerans metadata...",
+ "fetchingSnapshot": "Hämtar kamerabild..."
+ },
+ "probeFailed": "Misslyckades med att undersöka kameran: {{error}}",
+ "probingDevice": "Undersöker enheten...",
+ "probeSuccessful": "Kontroll lyckades",
+ "probeError": "Kontroll fel",
+ "probeNoSuccess": "Kontroll misslyckades",
+ "deviceInfo": "Enhetsinformation",
+ "manufacturer": "Tillverkare",
+ "model": "Modell",
+ "firmware": "Inbyggd programvara",
+ "profiles": "Profiler",
+ "ptzSupport": "PTZ-stöd",
+ "autotrackingSupport": "Stöd för Autospårning",
+ "presets": "Förinställningar",
+ "rtspCandidates": "RTSP-kandidater",
+ "rtspCandidatesDescription": "Följande RTSP-URL:er hittades från kamera kontrollen. Testa anslutningen för att visa strömmetadata.",
+ "noRtspCandidates": "Inga RTSP-URL:er hittades från kameran. Dina inloggningsuppgifter kan vara felaktiga, eller så kanske kameran inte stöder ONVIF eller metoden som används för att hämta RTSP-URL:er. Gå tillbaka och ange RTSP-URL:en manuellt.",
+ "candidateStreamTitle": "Kandidat {{number}}",
+ "useCandidate": "Använda",
+ "uriCopy": "Kopiera",
+ "uriCopied": "URI kopierad till urklipp",
+ "testConnection": "Testa anslutning",
+ "toggleUriView": "Klicka för att växla mellan fullständig URI-vy",
+ "errors": {
+ "hostRequired": "Värd-/IP-adress krävs"
+ }
+ },
+ "step3": {
+ "description": "Konfigurera strömningsroller och lägg till ytterligare strömmar för din kamera.",
+ "validationTitle": "Strömvalidering",
+ "connectAllStreams": "Anslut alla strömmar",
+ "reconnectionSuccess": "Återanslutningen lyckades.",
+ "reconnectionPartial": "Vissa strömmar kunde inte återanslutas.",
+ "streamUnavailable": "Förhandsgranskning av strömmen är inte tillgänglig",
+ "reload": "Ladda om",
+ "connecting": "Ansluter...",
+ "streamTitle": "Ström {{number}}",
+ "valid": "Giltig",
+ "failed": "Misslyckades",
+ "notTested": "Inte testad",
+ "connectStream": "Ansluta",
+ "connectingStream": "Ansluter",
+ "disconnectStream": "Koppla från",
+ "estimatedBandwidth": "Uppskattad bandbredd",
+ "roles": "Roller",
+ "none": "Ingen",
+ "error": "Fel",
+ "streamValidated": "Ström {{number}} har validerats",
+ "streamValidationFailed": "Validering av ström {{number}} misslyckades",
+ "saveAndApply": "Spara ny kamera",
+ "saveError": "Ogiltig konfiguration. Kontrollera dina inställningar.",
+ "issues": {
+ "title": "Strömvalidering",
+ "videoCodecGood": "Videokodeken är {{codec}}.",
+ "audioCodecGood": "Ljudkodeken är {{codec}}.",
+ "noAudioWarning": "Inget ljud upptäcktes för den här strömmen, inspelningarna kommer inte att ha något ljud.",
+ "audioCodecRecordError": "AAC-ljudkodeken krävs för att stödja ljud i inspelningar.",
+ "audioCodecRequired": "En ljudström krävs för att stödja ljuddetektering.",
+ "restreamingWarning": "Att minska anslutningarna till kameran för inspelningsströmmen kan öka CPU-användningen något.",
+ "dahua": {
+ "substreamWarning": "Delström 1 är låst till en låg upplösning. Många Dahua / Amcrest / EmpireTech kameror stöder ytterligare delströmmar som måste aktiveras i kamerans inställningar. Det rekommenderas att kontrollera och använda dessa strömmar om de är tillgängliga."
+ },
+ "hikvision": {
+ "substreamWarning": "Delström 1 är låst till en låg upplösning. Många Hikvision kameror stöder ytterligare delströmmar som måste aktiveras i kamerans inställningar. Det rekommenderas att kontrollera och använda dessa strömmar om de är tillgängliga."
+ },
+ "resolutionHigh": "En upplösning på {{resolution}} kan orsaka ökad resursanvändning.",
+ "resolutionLow": "En upplösning på {{resolution}} kan vara för låg för tillförlitlig detektering av små objekt."
+ },
+ "ffmpegModule": "Använd läge för strömkompatibilitet",
+ "ffmpegModuleDescription": "Om strömmen inte läses in efter flera försök, prova att aktivera detta. När det är aktiverat kommer Frigate att använda ffmpeg-modulen med go2rtc. Detta kan ge bättre kompatibilitet med vissa kameraströmmar.",
+ "streamsTitle": "Kameraströmmar",
+ "addStream": "Lägg till ström",
+ "addAnotherStream": "Lägg till ytterligare en ström",
+ "streamUrl": "Stream-URL",
+ "streamUrlPlaceholder": "rtsp://användarnamn:lösenord@värd:portnummer/plats",
+ "selectStream": "Välj en ström",
+ "searchCandidates": "Sök kandidater...",
+ "noStreamFound": "Ingen ström hittades",
+ "url": "URL",
+ "resolution": "Upplösning",
+ "selectResolution": "Välj upplösning",
+ "quality": "Kvalitet",
+ "selectQuality": "Välj kvalitet",
+ "roleLabels": {
+ "detect": "Objektdetektering",
+ "record": "Inspelning",
+ "audio": "Ljud"
+ },
+ "testStream": "Testa anslutning",
+ "testSuccess": "Streamtestet lyckades!",
+ "testFailed": "Strömtestet misslyckades",
+ "testFailedTitle": "Testet misslyckades",
+ "connected": "Ansluten",
+ "notConnected": "Inte ansluten",
+ "featuresTitle": "Funktioner",
+ "go2rtc": "Minska anslutningar till kameran",
+ "detectRoleWarning": "Minst en ström måste ha rollen \"upptäck\" för att fortsätta.",
+ "rolesPopover": {
+ "title": "Stream-roller",
+ "detect": "Huvud kamera flöde för objektdetektering.",
+ "record": "Sparar segment av videoflödet baserat på konfigurationsinställningar.",
+ "audio": "Flöde för ljudbaserad detektering."
+ },
+ "featuresPopover": {
+ "title": "Streamfunktioner",
+ "description": "Använd go2rtc-omströmning för att minska anslutningar till din kamera."
+ }
+ },
+ "step4": {
+ "description": "Slutgiltig validering och analys innan du sparar din nya kamera. Anslut varje ström innan du sparar.",
+ "validationTitle": "Ström validering",
+ "connectAllStreams": "Anslut alla strömmar",
+ "reconnectionSuccess": "Återanslutningen lyckades.",
+ "reconnectionPartial": "Vissa strömmar kunde inte återanslutas.",
+ "streamUnavailable": "Förhandsgranskning av strömmen är inte tillgänglig",
+ "reload": "Ladda om",
+ "connecting": "Ansluter...",
+ "streamTitle": "Ström {{number}}",
+ "valid": "Giltig",
+ "failed": "Misslyckades",
+ "notTested": "Inte testad",
+ "connectStream": "Ansluta",
+ "connectingStream": "Ansluter",
+ "disconnectStream": "Koppla från",
+ "estimatedBandwidth": "Uppskattad bandbredd",
+ "roles": "Roller",
+ "ffmpegModule": "Använd strömkompatibilitetsläge",
+ "ffmpegModuleDescription": "Om strömmen inte laddas efter flera försök, försök att aktivera detta. När det är aktiverat kommer Frigate att använda ffmpeg-modulen med go2rtc. Detta kan ge bättre kompatibilitet med vissa kameraströmmar.",
+ "none": "Ingen",
+ "error": "Fel",
+ "streamValidated": "Ström {{number}} har validerats",
+ "streamValidationFailed": "Validering av ström {{number}} misslyckades",
+ "saveAndApply": "Spara ny kamera",
+ "saveError": "Ogiltig konfiguration. Kontrollera dina inställningar.",
+ "issues": {
+ "title": "Ström validering",
+ "videoCodecGood": "Videokodeken är {{codec}}.",
+ "audioCodecGood": "Ljudkodeken är {{codec}}.",
+ "resolutionHigh": "En upplösning på {{resolution}} kan orsaka ökad resursanvändning.",
+ "resolutionLow": "En upplösning på {{resolution}} kan vara för låg för tillförlitlig detektering av små objekt.",
+ "noAudioWarning": "Inget ljud upptäcktes för den här strömmen, inspelningarna kommer inte att ha ljud.",
+ "audioCodecRecordError": "AAC-ljudkodeken krävs för att stödja ljud i inspelningar.",
+ "audioCodecRequired": "En ljudström krävs för att stödja ljuddetektering.",
+ "restreamingWarning": "Att minska anslutningarna till kameran för inspelningsströmmen kan öka CPU-användningen något.",
+ "brands": {
+ "reolink-rtsp": "Reolink RTSP rekommenderas inte. Aktivera HTTP i kamerans firmwareinställningar och starta om guiden.",
+ "reolink-http": "Reolink HTTP-strömmar bör använda FFmpeg för bättre kompatibilitet. Aktivera \"Använd strömkompatibilitetsläge\" för den här strömmen."
+ },
+ "dahua": {
+ "substreamWarning": "Delström 1 är låst till en låg upplösning. Många Dahua/Amcrest/EmpireTech-kameror stöder ytterligare delströmmar som måste aktiveras i kamerans inställningar. Det rekommenderas att kontrollera och använda dessa strömmar om de är tillgängliga."
+ },
+ "hikvision": {
+ "substreamWarning": "Delström 1 är låst till en låg upplösning. Många Hikvision-kameror stöder ytterligare delströmmar som måste aktiveras i kamerans inställningar. Det rekommenderas att kontrollera och använda dessa strömmar om de är tillgängliga."
+ }
+ }
+ }
+ },
+ "cameraManagement": {
+ "title": "Hantera kameror",
+ "addCamera": "Lägg till ny kamera",
+ "editCamera": "Redigera kamera:",
+ "selectCamera": "Välj en kamera",
+ "backToSettings": "Tillbaka till kamerainställningar",
+ "streams": {
+ "title": "Aktivera/avaktivera kameror",
+ "desc": "Inaktivera tillfälligt en kamera tills Frigate startar om. Om du inaktiverar en kamera helt stoppas Frigates bearbetning av kamerans strömmar. Detektering, inspelning och felsökning kommer inte att vara tillgängliga.
Obs! Detta inaktiverar inte go2rtc-återströmmar."
+ },
+ "cameraConfig": {
+ "add": "Lägg till kamera",
+ "edit": "Redigera kamera",
+ "description": "Konfigurera kamerainställningar inklusive strömingångar och roller.",
+ "name": "Kameranamn",
+ "nameRequired": "Kameranamn krävs",
+ "nameLength": "Kameranamnet måste vara kortare än 64 tecken.",
+ "namePlaceholder": "t.ex. ytterdörr eller Översikt över bakgård",
+ "enabled": "Aktiverad",
+ "ffmpeg": {
+ "inputs": "Ingångsströmmar",
+ "path": "Strömväg",
+ "pathRequired": "Strömväg krävs",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Roller",
+ "rolesRequired": "Minst en roll krävs",
+ "rolesUnique": "Varje roll (ljud, detektering, inspelning) kan bara tilldelas en ström",
+ "addInput": "Lägg till inmatningsström",
+ "removeInput": "Ta bort inmatningsström",
+ "inputsRequired": "Minst en indataström krävs"
+ },
+ "go2rtcStreams": "go2rtc-strömmar",
+ "streamUrls": "Ström-URL:er",
+ "addUrl": "Lägg till URL",
+ "addGo2rtcStream": "Lägg till go2rtc-ström",
+ "toast": {
+ "success": "Kamera {{cameraName}} sparades"
+ }
+ }
+ },
+ "cameraReview": {
+ "title": "Inställningar för kameragranskning",
+ "object_descriptions": {
+ "title": "Generativa AI-objektbeskrivningar",
+ "desc": "Aktivera/inaktivera generativa AI-objektbeskrivningar temporärt för den här kameran tills Frigate startas om. Vid inaktivering kommer AI-genererade beskrivningar inte att begäras för spårade objekt på den här kameran."
+ },
+ "review_descriptions": {
+ "title": "Beskrivningar av generativa AI-granskningar",
+ "desc": "Aktivera/inaktivera generativa AI-granskningsbeskrivningar för den här kameran temporärt tills Frigate startas om. Vid inaktivering kommer AI-genererade beskrivningar inte att begäras för granskningsobjekt på den här kameran."
+ },
+ "review": {
+ "title": "Granska",
+ "desc": "Tillfälligt aktivera/avaktivera varningar och detekteringar för den här kameran tills Frigate startar om. När den är avaktiverad genereras inga nya granskningsobjekt. ",
+ "alerts": "Aviseringar ",
+ "detections": "Detektioner "
+ },
+ "reviewClassification": {
+ "title": "Granska klassificering",
+ "desc": "Frigate kategoriserar granskningsobjekt som Varningar och Detekteringar. Som standard betraktas alla person- och bil-objekt som Varningar. Du kan förfina kategoriseringen av dina granskningsobjekt genom att konfigurera obligatoriska zoner för dem.",
+ "noDefinedZones": "Inga zoner är definierade för den här kameran.",
+ "objectAlertsTips": "Alla {{alertsLabels}}-objekt på {{cameraName}} kommer att visas som Varningar.",
+ "zoneObjectAlertsTips": "Alla {{alertsLabels}} objekt som upptäcks i {{zone}} på {{cameraName}} kommer att visas som Varningar.",
+ "objectDetectionsTips": "Alla {{detectionsLabels}}-objekt som inte kategoriseras på {{cameraName}} kommer att visas som Detektioner oavsett vilken zon de befinner sig i.",
+ "zoneObjectDetectionsTips": {
+ "text": "Alla {{detectionsLabels}}-objekt som inte kategoriseras i {{zone}} på {{cameraName}} kommer att visas som Detektioner.",
+ "notSelectDetections": "Alla {{detectionsLabels}} objekt som upptäckts i {{zone}} på {{cameraName}} och som inte kategoriserats som Varningar kommer att visas som Detekteringar oavsett vilken zon de befinner sig i.",
+ "regardlessOfZoneObjectDetectionsTips": "Alla {{detectionsLabels}}-objekt som inte kategoriseras på {{cameraName}} kommer att visas som Detektioner oavsett vilken zon de befinner sig i."
+ },
+ "unsavedChanges": "Osparade inställningar för granskningsklassificering för {{camera}}",
+ "selectAlertsZones": "Välj zoner för Varningar",
+ "selectDetectionsZones": "Välj zoner för Detektioner",
+ "limitDetections": "Begränsa detektioner till specifika zoner",
+ "toast": {
+ "success": "Konfigurationen för granskning av klassificering har sparats. Starta om Frigate för att tillämpa ändringarna."
+ }
+ }
}
}
diff --git a/web/public/locales/sv/views/system.json b/web/public/locales/sv/views/system.json
index d10bf2e1d..27eb9b844 100644
--- a/web/public/locales/sv/views/system.json
+++ b/web/public/locales/sv/views/system.json
@@ -4,9 +4,11 @@
"general": "Allmän statistik - Frigate",
"cameras": "Kamerastatistik - Frigate",
"logs": {
- "frigate": "Frigate loggar - Frigate",
- "go2rtc": "Go2RTC Loggar - Frigate"
- }
+ "frigate": "Frigate-loggar - Frigate",
+ "go2rtc": "Go2RTC loggar - Frigate",
+ "nginx": "Nginx loggar - Frigate"
+ },
+ "enrichments": "Förbättringsstatistik - Frigate"
},
"logs": {
"copy": {
@@ -32,19 +34,66 @@
}
},
"title": "System",
- "metrics": "System detaljer",
+ "metrics": "Systemdetaljer",
"general": {
"title": "Generellt",
"detector": {
- "title": "Detektorer"
+ "title": "Detektorer",
+ "inferenceSpeed": "Detektorns inferenshastighet",
+ "temperature": "Detektor temperatur",
+ "cpuUsage": "Detektorns CPU-användning",
+ "memoryUsage": "Detektor minnes användning",
+ "cpuUsageInformation": "CPU som används för att förbereda in- och utdata till/från detekteringsmodeller. Detta värde mäter inte inferensanvändning, även om en GPU eller accelerator används."
},
"hardwareInfo": {
"title": "Hårdvaruinformation",
"gpuUsage": "GPU-användning",
- "gpuMemory": "GPU-minne"
+ "gpuMemory": "GPU-minne",
+ "gpuEncoder": "GPU-kodare",
+ "gpuDecoder": "GPU-avkodare",
+ "gpuInfo": {
+ "nvidiaSMIOutput": {
+ "vbios": "VBios-information: {{vbios}}",
+ "title": "Nvidia SMI utdata",
+ "name": "Namn: {{name}}",
+ "driver": "Drivrutin: {{driver}}",
+ "cudaComputerCapability": "CUDA beräknings kapacitet: {{cuda_compute}}"
+ },
+ "closeInfo": {
+ "label": "Stäng GPU-info"
+ },
+ "copyInfo": {
+ "label": "Kopiera GPU-info"
+ },
+ "toast": {
+ "success": "Kopierade GPU-info till urklipp"
+ },
+ "vainfoOutput": {
+ "title": "Vainfo resultat",
+ "returnCode": "Returkod: {{code}}",
+ "processOutput": "Bearbeta utdata:",
+ "processError": "Processfel:"
+ }
+ },
+ "npuUsage": "NPU-användning",
+ "npuMemory": "NPU-minne",
+ "intelGpuWarning": {
+ "title": "Intel GPU statistik varning",
+ "message": "GPU statistik otillgänglig",
+ "description": "Detta är en känd bugg i Intels GPU-statistikrapporteringsverktyg (intel_gpu_top) där den slutar fungera och upprepade gånger returnerar en GPU-användning på 0 %, även i fall där hårdvaruacceleration och objektdetektering körs korrekt på (i)GPU:n. Detta är inte en Frigate-bugg. Du kan starta om värden för att tillfälligt åtgärda problemet och bekräfta att GPU:n fungerar korrekt. Detta påverkar inte prestandan."
+ }
},
"otherProcesses": {
- "title": "Övriga processer"
+ "title": "Övriga processer",
+ "processCpuUsage": "Process CPU-användning",
+ "processMemoryUsage": "Processminnesanvändning",
+ "series": {
+ "go2rtc": "go2rtc",
+ "recording": "inspelning",
+ "review_segment": "granskningssegment",
+ "embeddings": "inbäddningar",
+ "audio_detector": "ljuddetektor"
+ }
}
},
"storage": {
@@ -55,17 +104,105 @@
"unused": {
"title": "Oanvänt",
"tips": "Det här värdet kanske inte korrekt representerar det lediga utrymmet tillgängligt för Frigate om du har andra filer lagrade på din hårddisk utöver Frigates inspelningar. Frigate spårar inte lagringsanvändning utanför sina egna inspelningar."
- }
+ },
+ "title": "Kamera lagring",
+ "camera": "Kamera",
+ "unusedStorageInformation": "Information om oanvänd lagring"
+ },
+ "title": "Lagring",
+ "overview": "Översikt",
+ "recordings": {
+ "title": "Inspelningar",
+ "tips": "Detta värde representerar den totala lagringsmängden som används av inspelningarna i Frigates databas. Frigate spårar inte lagringsanvändningen för alla filer på din disk.",
+ "earliestRecording": "Tidigast tillgängliga inspelning:"
+ },
+ "shm": {
+ "title": "SHM-allokering (delat minne)",
+ "warning": "Den nuvarande SHM-storleken på {{total}}MB är för liten. Öka den till minst {{min_shm}}MB."
}
},
"cameras": {
"title": "Kameror",
"overview": "Översikt",
"info": {
- "aspectRatio": "bildförhållande"
+ "aspectRatio": "bildförhållande",
+ "cameraProbeInfo": "{{camera}} Kamerasondinformation",
+ "streamDataFromFFPROBE": "Strömdata erhålls med ffprobe.",
+ "codec": "Codec:",
+ "resolution": "Upplösning:",
+ "fps": "FPS:",
+ "unknown": "Okänd",
+ "audio": "Ljud:",
+ "error": "Fel: {{error}}",
+ "tips": {
+ "title": "Kamera sond information"
+ },
+ "fetching": "Hämtar kamera data",
+ "stream": "Ström {{idx}}",
+ "video": "Video:"
},
"label": {
- "detect": "detektera"
+ "detect": "detektera",
+ "camera": "kamera",
+ "skipped": "hoppade över",
+ "ffmpeg": "FFmpeg",
+ "capture": "spela in",
+ "overallFramesPerSecond": "totalt antal bilder per sekund",
+ "overallDetectionsPerSecond": "totala detektioner per sekund",
+ "overallSkippedDetectionsPerSecond": "totalt antal hoppade detekteringar per sekund",
+ "cameraFfmpeg": "{{camName}} FFmpeg",
+ "cameraCapture": "{{camName}} inspelning",
+ "cameraDetect": "{{camName}} upptäcka",
+ "cameraFramesPerSecond": "{{camName}} bildrutor per sekund",
+ "cameraDetectionsPerSecond": "{{camName}} detekteringar per sekund",
+ "cameraSkippedDetectionsPerSecond": "{{camName}} hoppade över detekteringar per sekund"
+ },
+ "framesAndDetections": "Ramar / Detektioner",
+ "toast": {
+ "success": {
+ "copyToClipboard": "Kopierade probdata till urklipp."
+ },
+ "error": {
+ "unableToProbeCamera": "Kunde inte undersöka kameran: {{errorMessage}}"
+ }
}
+ },
+ "lastRefreshed": "Senast uppdaterad: ",
+ "stats": {
+ "ffmpegHighCpuUsage": "{{camera}} har hög FFmpeg CPU-användning ({{ffmpegAvg}}%)",
+ "detectHighCpuUsage": "{{camera}} har hög CPU-användning vid detektering ({{detectAvg}}%)",
+ "healthy": "Systemet är hälsosamt",
+ "reindexingEmbeddings": "Omindexering av inbäddningar ({{processed}}% klar)",
+ "cameraIsOffline": "{{camera}} är urkopplad",
+ "detectIsSlow": "{{detect}} är långsam ({{speed}} ms)",
+ "detectIsVerySlow": "{{detect}} är väldigt långsam ({{speed}} ms)",
+ "shmTooLow": "/dev/shm allokeringen ({{total}} MB) bör ökas till minst {{min}} MB."
+ },
+ "enrichments": {
+ "title": "Berikningar",
+ "infPerSecond": "Slutsatser per sekund",
+ "embeddings": {
+ "image_embedding": "Bildinbäddning",
+ "text_embedding": "Textinbäddning",
+ "face_recognition": "Ansiktsigenkänning",
+ "plate_recognition": "Nummerplåt igenkänning",
+ "image_embedding_speed": "Bildinbäddningshastighet",
+ "face_embedding_speed": "Ansikts inbäddnings hastighet",
+ "face_recognition_speed": "Ansiktsigenkänningshastighet",
+ "plate_recognition_speed": "Hastighet för igenkänning av nummerplåtar",
+ "text_embedding_speed": "Textinbäddningshastighet",
+ "yolov9_plate_detection_speed": "YOLOv9 nummerplåt detekterings hastighet",
+ "yolov9_plate_detection": "YOLOv9 nummerplåt detektering",
+ "review_description": "Recensionsbeskrivning",
+ "review_description_speed": "Recensionsbeskrivning Hastighet",
+ "review_description_events_per_second": "Recensionsbeskrivning",
+ "object_description": "Objekt beskrivning",
+ "object_description_speed": "Objekt beskrivning hastighet",
+ "object_description_events_per_second": "Objekt beskrivning",
+ "classification_events_per_second": "{{name}} Klassificering Händelser per sekund",
+ "classification": "{{name}} Klassificering",
+ "classification_speed": "{{name}} Klassificeringshastighet"
+ },
+ "averageInf": "Genomsnittlig inferenstid"
}
}
diff --git a/web/public/locales/ta/audio.json b/web/public/locales/ta/audio.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/audio.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/common.json b/web/public/locales/ta/common.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/common.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/components/auth.json b/web/public/locales/ta/components/auth.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/components/auth.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/components/camera.json b/web/public/locales/ta/components/camera.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/components/camera.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/components/dialog.json b/web/public/locales/ta/components/dialog.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/components/dialog.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/components/filter.json b/web/public/locales/ta/components/filter.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/components/filter.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/components/icons.json b/web/public/locales/ta/components/icons.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/components/icons.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/components/input.json b/web/public/locales/ta/components/input.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/components/input.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/components/player.json b/web/public/locales/ta/components/player.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/components/player.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/objects.json b/web/public/locales/ta/objects.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/objects.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/classificationModel.json b/web/public/locales/ta/views/classificationModel.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/classificationModel.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/configEditor.json b/web/public/locales/ta/views/configEditor.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/configEditor.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/events.json b/web/public/locales/ta/views/events.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/events.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/explore.json b/web/public/locales/ta/views/explore.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/explore.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/exports.json b/web/public/locales/ta/views/exports.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/exports.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/faceLibrary.json b/web/public/locales/ta/views/faceLibrary.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/faceLibrary.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/live.json b/web/public/locales/ta/views/live.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/live.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/recording.json b/web/public/locales/ta/views/recording.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/recording.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/search.json b/web/public/locales/ta/views/search.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/search.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/settings.json b/web/public/locales/ta/views/settings.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/settings.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/ta/views/system.json b/web/public/locales/ta/views/system.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ta/views/system.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/th/common.json b/web/public/locales/th/common.json
index c7044976d..b92078797 100644
--- a/web/public/locales/th/common.json
+++ b/web/public/locales/th/common.json
@@ -246,5 +246,6 @@
"feet": "ฟุต",
"meters": "เมตร"
}
- }
+ },
+ "readTheDocumentation": "อ่านเอกสาร"
}
diff --git a/web/public/locales/th/components/filter.json b/web/public/locales/th/components/filter.json
index aea9fc5a7..5f23f3142 100644
--- a/web/public/locales/th/components/filter.json
+++ b/web/public/locales/th/components/filter.json
@@ -82,5 +82,8 @@
},
"title": "การตั้งค่า"
}
+ },
+ "classes": {
+ "label": "หมวดหมู่"
}
}
diff --git a/web/public/locales/th/views/classificationModel.json b/web/public/locales/th/views/classificationModel.json
new file mode 100644
index 000000000..3181c4e9f
--- /dev/null
+++ b/web/public/locales/th/views/classificationModel.json
@@ -0,0 +1,9 @@
+{
+ "documentTitle": "โมเดลการจำแนกประเภท- Frigate",
+ "details": {
+ "scoreInfo": "คะแนน (Score) คือค่าเฉลี่ยของความมั่นใจในการจำแนกประเภท (Classification Confidence) จากการตรวจจับวัตถุชิ้นนี้ในทุกๆ ครั้ง"
+ },
+ "description": {
+ "invalidName": "ชื่อไม่ถูกต้อง ชื่อสามารถประกอบได้ด้วยตัวอักษร, ตัวเลข, ช่องว่าง, เครื่องหมาย ( ' , _ , - ) เท่านั้น"
+ }
+}
diff --git a/web/public/locales/th/views/faceLibrary.json b/web/public/locales/th/views/faceLibrary.json
index 4372d09b5..c6ad3e750 100644
--- a/web/public/locales/th/views/faceLibrary.json
+++ b/web/public/locales/th/views/faceLibrary.json
@@ -43,8 +43,9 @@
},
"collections": "คอลเลกชัน",
"description": {
- "addFace": "ทำตามวิธีการเพิ่มคอลเลกชันใหม่ไปยังที่เก็บหน้า.",
- "placeholder": "ใส่ชื่อสําหรับคอลเลกชันนี้"
+ "addFace": "เพิ่มคอลเลกชันใหม่ไปยังคลังใบหน้า โดยการอัปโหลดรูปภาพแรก",
+ "placeholder": "ใส่ชื่อสําหรับคอลเลกชันนี้",
+ "invalidName": "ชื่อไม่ถูกต้อง ชื่อสามารถประกอบได้ด้วยตัวอักษร, ตัวเลข, ช่องว่าง, เครื่องหมาย ( ' , _ , - ) เท่านั้น"
},
"toast": {
"success": {
diff --git a/web/public/locales/th/views/system.json b/web/public/locales/th/views/system.json
index 2084d91a3..fd0010fdd 100644
--- a/web/public/locales/th/views/system.json
+++ b/web/public/locales/th/views/system.json
@@ -55,5 +55,10 @@
"stats": {
"cameraIsOffline": "{{camera}} ออฟไลน์",
"detectIsVerySlow": "{{detect}} ช้ามาก ({{speed}} มิลลิวินาที)"
+ },
+ "documentTitle": {
+ "cameras": "ข้อมูลกล้อง - Frigate",
+ "storage": "สถิติคลังข้อมูล - Frigate",
+ "general": "สถิติทั่วไป - Frigate"
}
}
diff --git a/web/public/locales/tr/audio.json b/web/public/locales/tr/audio.json
index 6364c8dcd..34a6f366f 100644
--- a/web/public/locales/tr/audio.json
+++ b/web/public/locales/tr/audio.json
@@ -32,7 +32,7 @@
"sheep": "koyun",
"train": "tren",
"hair_dryer": "saç kurutma makinesi",
- "babbling": "aguşlama",
+ "babbling": "Agulama",
"snicker": "kıkırdama",
"sigh": "iç çekme",
"bellow": "haykırma",
@@ -425,5 +425,79 @@
"radio": "radyo",
"field_recording": "alan kaydı",
"scream": "çığlık",
- "jingle_bell": "küçük çan"
+ "jingle_bell": "küçük çan",
+ "sodeling": "Jodel (Yodeling)",
+ "chird": "Cıvıltı",
+ "change_ringing": "Sıralı Çan Çalma",
+ "shofar": "Şofar",
+ "liquid": "Sıvı",
+ "splash": "Su Sıçraması",
+ "slosh": "Çalkalanma",
+ "squish": "Vıcıklama (Islak Ezilme)",
+ "drip": "Damlama",
+ "pour": "Dökülme",
+ "trickle": "Şırıldama / İnce Akış",
+ "gush": "Fışkırma",
+ "fill": "Doldurma",
+ "spray": "Püskürtme / Sprey",
+ "pump": "Pompalama",
+ "stir": "Karıştırma",
+ "boiling": "Kaynama",
+ "sonar": "Sonar Sesi",
+ "arrow": "Ok Sesi",
+ "whoosh": "Hışırtı (Hızlı Geçiş Sesi)",
+ "thump": "Küt Sesi (Boğuk)",
+ "thunk": "Tok Ses",
+ "electronic_tuner": "Elektronik Akort Cihazı",
+ "effects_unit": "Efekt Ünitesi",
+ "chorus_effect": "Chorus (Koro) Efekti",
+ "basketball_bounce": "Basketbol Topu Sektirme",
+ "bang": "Gümleme / Patlama",
+ "slap": "Tokat / Şaplak",
+ "whack": "Sert Vuruş / Kütletme",
+ "smash": "Parçalanma",
+ "breaking": "Kırılma",
+ "bouncing": "Sekme / Zıplama",
+ "whip": "Kırbaç",
+ "flap": "Kanat Çırpma / Pırpır Etme",
+ "scratch": "Tırmalama / Cızırtı",
+ "scrape": "Kazıma / Sürtünme",
+ "rub": "Ovma / Sürtme",
+ "roll": "Yuvarlanma",
+ "crushing": "Ezilme (Kuru/Sert)",
+ "crumpling": "Buruşturma",
+ "tearing": "Yırtılma",
+ "beep": "Bip Sesi",
+ "ping": "Ping Sesi (Çınlama)",
+ "ding": "Ding (Zil Sesi)",
+ "clang": "Çangırtı (Metalik)",
+ "squeal": "Ciyaklama / Acı Gıcırtı",
+ "creak": "Gıcırdama (Tahta/Kapı)",
+ "rustle": "Hışırtı (Kağıt/Yaprak)",
+ "whir": "Vızıltı (Motor/Pervane)",
+ "clatter": "Takırtı",
+ "sizzle": "Cızırdayarak Kızarma",
+ "clicking": "Tıklama",
+ "clickety_clack": "Takır Tukur Sesi",
+ "rumble": "Gürleme / Gümbürtü",
+ "plop": "Lup Sesi (Suya düşme)",
+ "hum": "Uğultu / Mırıldanma",
+ "zing": "Vınlama",
+ "boing": "Boing (Yay Sesi)",
+ "crunch": "Kıtırdatma / Çıtırdatma",
+ "sine_wave": "Sinüs Dalgası",
+ "harmonic": "Harmonik",
+ "chirp_tone": "Cıvıltı Tonu (Sinyal)",
+ "pulse": "Darbe / Pulse",
+ "inside": "İç Mekan",
+ "outside": "Dış Mekan",
+ "reverberation": "Yankılanım (Reverb)",
+ "echo": "Yankı",
+ "noise": "Gürültü",
+ "mains_hum": "Şebeke Uğultusu (Elektrik)",
+ "distortion": "Bozulma / Distorsiyon",
+ "sidetone": "Yan Ton",
+ "cacophony": "Kakofoni (Ses Kargaşası)",
+ "throbbing": "Zonklama",
+ "vibration": "Titreşim"
}
diff --git a/web/public/locales/tr/common.json b/web/public/locales/tr/common.json
index e23b402ca..2a97d8d0f 100644
--- a/web/public/locales/tr/common.json
+++ b/web/public/locales/tr/common.json
@@ -81,7 +81,11 @@
"formattedTimestampMonthDayYear": {
"12hour": "d MMM, yyyy",
"24hour": "d MMM, yyyy"
- }
+ },
+ "inProgress": "Devam ediyor",
+ "invalidStartTime": "Geçersiz başlangıç zamanı",
+ "invalidEndTime": "Geçersiz bitiş zamanı",
+ "never": "Asla"
},
"button": {
"off": "KAPALI",
@@ -101,14 +105,14 @@
"export": "Dışa aktar",
"download": "İndir",
"edit": "Düzenle",
- "fullscreen": "Tam ekran",
+ "fullscreen": "Tam Ekran",
"deleteNow": "Şimdi Sil",
"apply": "Uygula",
"reset": "Sıfırla",
"done": "Bitti",
"enabled": "Açık",
"save": "Kaydet",
- "exitFullscreen": "Tam ekrandan çık",
+ "exitFullscreen": "Tam Ekrandan Çık",
"pictureInPicture": "Pencere içinde pencere",
"copyCoordinates": "Koordinatları kopyala",
"yes": "Evet",
@@ -118,7 +122,8 @@
"cancel": "İptal",
"twoWayTalk": "Çift Yönlü Ses",
"close": "Kapat",
- "delete": "Sil"
+ "delete": "Sil",
+ "continue": "Devam Et"
},
"menu": {
"systemLogs": "Sistem günlükleri",
@@ -166,7 +171,15 @@
"ru": "Русский (Rusça)",
"yue": "粵語 (Kantonca)",
"th": "ไทย (Tayca)",
- "ca": "Català (Katalanca)"
+ "ca": "Català (Katalanca)",
+ "ptBR": "Português brasileiro (Brezilya Portekizcesi)",
+ "sr": "Српски (Sırpça)",
+ "sl": "Slovenščina (Slovence)",
+ "lt": "Lietuvių (Litvanyaca)",
+ "bg": "Български (Bulgarca)",
+ "gl": "Galego (Galiçyaca)",
+ "id": "Bahasa Indonesia (Endonezce)",
+ "ur": "اردو (Urduca)"
},
"withSystem": "Sistem",
"theme": {
@@ -211,10 +224,17 @@
"help": "Yardım",
"faceLibrary": "Yüz Veritabanı",
"systemMetrics": "Sistem metrikleri",
- "uiPlayground": "UI Deneme Alanı"
+ "uiPlayground": "UI Deneme Alanı",
+ "classification": "Sınıflandırma"
},
"label": {
- "back": "Geri"
+ "back": "Geri",
+ "hide": "{{item}} öğesini gizle",
+ "show": "{{item}} öğesini göster",
+ "ID": "ID",
+ "none": "Hiçbiri",
+ "all": "Tümü",
+ "other": "Diğer"
},
"notFound": {
"documentTitle": "Bulunamadı - Frigate",
@@ -229,6 +249,14 @@
"length": {
"feet": "feet",
"meters": "metre"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/saat",
+ "mbph": "MB/saat",
+ "gbph": "GB/saat"
}
},
"pagination": {
@@ -264,5 +292,18 @@
"viewer": "Görüntüleyici",
"admin": "Yönetici",
"desc": "Yöneticiler Frigate arayüzündeki bütün özelliklere tam erişim sahibidir. Görüntüleyiciler ise yalnızca kameraları, eski görüntüleri ve inceleme öğelerini görüntülemekle sınırlıdır."
+ },
+ "readTheDocumentation": "Dökümantasyonu oku",
+ "list": {
+ "two": "{{0}} ve {{1}}",
+ "many": "{{items}} ve {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "İsteğe bağlı",
+ "internalID": "Frigate’ın yapılandırma ve veritabanında kullandığı Dahili Kimlik"
+ },
+ "information": {
+ "pixels": "{{area}}px"
}
}
diff --git a/web/public/locales/tr/components/auth.json b/web/public/locales/tr/components/auth.json
index dbc444b05..b66836bae 100644
--- a/web/public/locales/tr/components/auth.json
+++ b/web/public/locales/tr/components/auth.json
@@ -10,6 +10,7 @@
"rateLimit": "İstek sınırı aşıldı. Daha sonra tekrar deneyin.",
"unknownError": "Bilinmeyen hata. Günlükleri kontrol edin."
},
- "user": "Kullanıcı Adı"
+ "user": "Kullanıcı Adı",
+ "firstTimeLogin": "İlk kez giriş yapmayı mı deniyorsunuz? Giriş bilgileri Frigate günlüklerinde görüntülenir."
}
}
diff --git a/web/public/locales/tr/components/camera.json b/web/public/locales/tr/components/camera.json
index 8471d7c84..7885c2653 100644
--- a/web/public/locales/tr/components/camera.json
+++ b/web/public/locales/tr/components/camera.json
@@ -51,7 +51,8 @@
},
"placeholder": "Bir yayın seçin",
"stream": "Yayın"
- }
+ },
+ "birdseye": "Kuş Bakışı"
},
"icon": "Simge",
"add": "Kamera Grubu Ekle",
diff --git a/web/public/locales/tr/components/dialog.json b/web/public/locales/tr/components/dialog.json
index acdb8ef1e..35fe45170 100644
--- a/web/public/locales/tr/components/dialog.json
+++ b/web/public/locales/tr/components/dialog.json
@@ -59,12 +59,13 @@
"export": "Dışa Aktar",
"selectOrExport": "Seç veya Dışa Aktar",
"toast": {
- "success": "Dışa aktarım başladı. Dosyaya /exports klasöründe veya Dışa Aktar sekmesinden ulaşabilirsiniz.",
+ "success": "Dışa aktarma başarıyla başlatıldı. Dosyayı dışa aktarmalar sayfasında görüntüleyebilirsiniz.",
"error": {
"failed": "Dışa aktarım başlatılamadı: {{error}}",
"endTimeMustAfterStartTime": "Bitiş zamanı başlangıç zamanından sonra olmalıdır",
"noVaildTimeSelected": "Geçerli bir zaman aralığı seçilmedi"
- }
+ },
+ "view": "Görüntüle"
},
"fromTimeline": {
"saveExport": "Dışa Aktarımı Kaydet",
@@ -117,7 +118,16 @@
"button": {
"export": "Dışa Aktar",
"markAsReviewed": "İncelendi olarak işaretle",
- "deleteNow": "Şimdi Sil"
+ "deleteNow": "Şimdi Sil",
+ "markAsUnreviewed": "Gözden geçirilmedi olarak işaretle"
}
+ },
+ "imagePicker": {
+ "selectImage": "Takip edilen nesnenin küçük resmini seçin",
+ "noImages": "Bu kamera için küçük resim bulunamadı",
+ "search": {
+ "placeholder": "Etiket/alt etiket kullanarak arama yapın..."
+ },
+ "unknownLabel": "Kaydedilen Tetikleme Görseli"
}
}
diff --git a/web/public/locales/tr/components/filter.json b/web/public/locales/tr/components/filter.json
index 96565946f..ef178d4a0 100644
--- a/web/public/locales/tr/components/filter.json
+++ b/web/public/locales/tr/components/filter.json
@@ -108,7 +108,7 @@
"error": "Takip edilen nesneler silinemedi: {{errorMessage}}"
},
"title": "Silmeyi onayla",
- "desc": "Bu {{objectLength}} adet izlenen nesneyi sildiğinizde ilgili tüm fotoğraflar, kaydedilmiş tüm gömüler ve ilişkili tüm Nesne Geçmişi kayıtları kaldırılır. Bu izlenen nesnelere ait Geçmiş görünümündeki kayıtlı görüntüler SİLİNMEYECEKTİR.
Devam etmek istediğinize emin misiniz?
Gelecekte bu diyaloğu pas geçmek için Shift tuşuna basılı tutarak tıklayın."
+ "desc": "Bu {{objectLength}} adet izlenen nesneyi sildiğinizde ilgili tüm fotoğraflar, kaydedilmiş tüm gömüler ve ilişkili tüm nesne yaşam döngüsü kayıtları kaldırılır. Bu izlenen nesnelere ait Geçmiş görünümündeki kayıtlı görüntüler SİLİNMEYECEKTİR.
Devam etmek istediğinize emin misiniz?
Gelecekte bu diyaloğu pas geçmek için Shift tuşuna basılı tutarak tıklayın."
},
"recognizedLicensePlates": {
"selectPlatesFromList": "Listeden bir veya birden fazla plaka seçin.",
@@ -116,12 +116,26 @@
"loading": "Tanınan plakalar yükleniyor…",
"title": "Tanınan Plakalar",
"noLicensePlatesFound": "Plaka bulunamadı.",
- "loadFailed": "Tanınan plakalar yüklenemedi."
+ "loadFailed": "Tanınan plakalar yüklenemedi.",
+ "selectAll": "Tümünü seç",
+ "clearAll": "Tümünü temizle"
},
"motion": {
"showMotionOnly": "Yalnızca Hareket Olanları Göster"
},
"zoneMask": {
"filterBy": "Alana göre filtrele"
+ },
+ "classes": {
+ "count_one": "{{count}} Sınıf",
+ "count_other": "{{count}} Sınıf",
+ "label": "Sınıflar",
+ "all": {
+ "title": "Tüm Sınıflar"
+ }
+ },
+ "attributes": {
+ "label": "Sınıflandırma Özellikleri",
+ "all": "Tüm Özellikler"
}
}
diff --git a/web/public/locales/tr/views/classificationModel.json b/web/public/locales/tr/views/classificationModel.json
new file mode 100644
index 000000000..2081188aa
--- /dev/null
+++ b/web/public/locales/tr/views/classificationModel.json
@@ -0,0 +1,188 @@
+{
+ "documentTitle": "Sınıflandırma Modelleri - Frigate",
+ "details": {
+ "scoreInfo": "Skor, modelin nesneyi tespit ettiği tüm durumlar için ortalama güven düzeyini gösterir.",
+ "none": "Hiçbiri",
+ "unknown": "Bilinmiyor"
+ },
+ "button": {
+ "deleteClassificationAttempts": "Sınıflandırma Fotoğraflarını Sil",
+ "renameCategory": "Sınıfı Yeniden Adlandır",
+ "deleteCategory": "Sınıfı Sil",
+ "deleteImages": "Fotoğrafları Sil",
+ "trainModel": "Modeli Eğit",
+ "addClassification": "Sınıflandırma Ekle",
+ "deleteModels": "Modelleri Sil",
+ "editModel": "Modeli Düzenle"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Silinmiş Sınıf",
+ "deletedImage": "Silinmiş Fotoğraflar",
+ "deletedModel_one": "{{count}} model başarıyla silindi",
+ "deletedModel_other": "{{count}} model başarıyla silindi",
+ "categorizedImage": "Fotoğraf Başarıyla Sınıflandırıldı",
+ "trainedModel": "Model başarıyla eğitildi.",
+ "trainingModel": "Model eğitimi başarıyla başladı.",
+ "updatedModel": "Model yapılandırması başarıyla güncellendi",
+ "renamedCategory": "Sınıf başarıyla {{name}} olarak yeniden adlandırıldı"
+ },
+ "error": {
+ "deleteImageFailed": "Silinemedi: {{errorMessage}}",
+ "deleteModelFailed": "Model silinemedi: {{errorMessage}}",
+ "categorizeFailed": "Görsel sınıflandırılamadı: {{errorMessage}}",
+ "trainingFailed": "Model eğitimi başarısız oldu. Ayrıntılar için Frigate günlüklerini kontrol edin.",
+ "deleteCategoryFailed": "Sınıf silinemedi: {{errorMessage}}",
+ "trainingFailedToStart": "Model eğitimi başlatılamadı: {{errorMessage}}",
+ "updateModelFailed": "Model güncellenemedi: {{errorMessage}}",
+ "renameCategoryFailed": "Sınıf yeniden adlandırılamadı: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Sınıfı Sil",
+ "desc": "{{name}} adlı sınıfı silmek istediğinizden emin misiniz? Bu işlem, sınıfa ait tüm görselleri kalıcı olarak silecek ve modelin yeniden eğitilmesini gerektirecektir.",
+ "minClassesTitle": "Sınıf Silinemiyor",
+ "minClassesDesc": "Bu sınıfı silmeden önce bir sınıflandırma modelinin en az 2 sınıfa sahip olması gerekir. Bu sınıfı silmeden önce başka bir sınıf ekleyin."
+ },
+ "deleteModel": {
+ "title": "Sınıflandırma Modelini Sil",
+ "single": "{{name}} öğesini silmek istediğinizden emin misiniz? Bu işlem, görseller ve eğitim verileri dâhil olmak üzere tüm ilişkili verileri kalıcı olarak silecektir. Bu işlem geri alınamaz.",
+ "desc_one": "{{count}} modeli silmek istediğinizden emin misiniz? Bu işlem, görseller ve eğitim verileri dâhil olmak üzere tüm ilişkili verileri kalıcı olarak silecektir. Bu işlem geri alınamaz.",
+ "desc_other": "{{count}} modeli silmek istediğinizden emin misiniz? Bu işlem, görseller ve eğitim verileri dâhil olmak üzere tüm ilişkili verileri kalıcı olarak silecektir. Bu işlem geri alınamaz."
+ },
+ "deleteDatasetImages": {
+ "title": "Eğitim verisi görsellerini sil",
+ "desc_one": "{{dataset}} veri kümesinden {{count}} görseli silmek istediğinizden emin misiniz? Bu işlem geri alınamaz ve modelin yeniden eğitilmesini gerektirir.",
+ "desc_other": "{{dataset}} veri kümesinden {{count}} görseli silmek istediğinizden emin misiniz? Bu işlem geri alınamaz ve modelin yeniden eğitilmesini gerektirir."
+ },
+ "deleteTrainImages": {
+ "title": "Eğitim Görsellerini Sil",
+ "desc_one": "{{count}} görseli silmek istediğinizden emin misiniz? Bu işlem geri alınamaz.",
+ "desc_other": "{{count}} görseli silmek istediğinizden emin misiniz? Bu işlem geri alınamaz."
+ },
+ "renameCategory": {
+ "title": "Sınıfı Yeniden Adlandır",
+ "desc": "{{name}} için yeni bir ad girin. Ad değişikliğinin geçerli olması için modeli yeniden eğitmeniz gerekecektir."
+ },
+ "description": {
+ "invalidName": "Geçersiz isim. İsimler; yalnızca harf, rakam, boşluk, kesme işareti (’), alt çizgi(_) ve tire (-) içerebilir."
+ },
+ "train": {
+ "title": "Son Sınıflandırmalar",
+ "titleShort": "Son",
+ "aria": "Son Sınıflandırmaları Seç"
+ },
+ "categories": "Sınıflar",
+ "createCategory": {
+ "new": "Yeni Sınıf Oluştur"
+ },
+ "categorizeImageAs": "Görseli Şu Şekilde Sınıflandır:",
+ "categorizeImage": "Görseli Sınıflandır",
+ "menu": {
+ "objects": "Nesneler",
+ "states": "Durumlar"
+ },
+ "noModels": {
+ "object": {
+ "title": "Nesne sınıflandırma modeli mevcut değil",
+ "description": "Algılanan nesneleri sınıflandırmak için özel bir model oluşturun.",
+ "buttonText": "Nesne Modeli Oluştur"
+ },
+ "state": {
+ "title": "Durum Sınıflandırma Modeli Yok",
+ "description": "Belirli kamera alanlarındaki durum değişimlerini izlemek ve sınıflandırmak için özel bir model oluşturun.",
+ "buttonText": "Durum Modeli Oluştur"
+ }
+ },
+ "tooltip": {
+ "trainingInProgress": "Model şu anda eğitiliyor",
+ "noNewImages": "Eğitilecek yeni görsel bulunmuyor. Önce veri kümesinde daha fazla görseli sınıflandırın.",
+ "noChanges": "Son eğitimden bu yana veri kümesinde herhangi bir değişiklik yapılmadı.",
+ "modelNotReady": "Model eğitim için hazır değil"
+ },
+ "edit": {
+ "title": "Sınıflandırma Modelini Düzenle",
+ "descriptionState": "Bu durum sınıflandırma modeli için sınıfları düzenleyin. Değişiklikler, modelin yeniden eğitilmesini gerektirecektir.",
+ "descriptionObject": "Bu nesne sınıflandırma modeli için nesne türünü ve sınıflandırma türünü düzenleyin.",
+ "stateClassesInfo": "Not: Durum sınıflarını değiştirmek, modelin güncellenmiş sınıflarla yeniden eğitilmesini gerektirir."
+ },
+ "wizard": {
+ "title": "Yeni Sınıflandırma Oluştur",
+ "steps": {
+ "nameAndDefine": "İsim ver ve Tanımla",
+ "stateArea": "Durum Alanı",
+ "chooseExamples": "Örnekleri Seç"
+ },
+ "step1": {
+ "description": "Durum modelleri, sabit kamera alanlarındaki değişiklikleri (ör. kapının açılması/kapanması) izler. Nesne modelleri ise algılanan nesnelere ek sınıflandırmalar ekler (ör. bilinen hayvanlar, kuryeler vb.).",
+ "name": "İsim",
+ "namePlaceholder": "Model ismi girin...",
+ "type": "Tür",
+ "typeState": "Durum",
+ "typeObject": "Nesne",
+ "objectLabel": "Nesne Etiketi",
+ "objectLabelPlaceholder": "Nesne türünü seçin...",
+ "classificationType": "Sınıflandırma Türü",
+ "classificationTypeTip": "Sınıflandırma türleri hakkında bilgi edinin",
+ "classificationTypeDesc": "Alt etiketler, nesne etiketine ek olarak saklanır (örneğin: “Person: UPS”). Öznitelikler(attributes) ise nesne meta verilerinde saklanan aranabilir meta verilerdir.",
+ "classificationSubLabel": "Alt Etiket",
+ "classificationAttribute": "Özellik",
+ "classes": "Sınıflar",
+ "states": "Durumlar",
+ "classesTip": "Sınıflar hakkında bilgi edinin",
+ "classesStateDesc": "Kamera alanınızın içinde bulunabileceği farklı durumları tanımlayın. Örneğin: bir garaj kapısı için ‘açık’ ve ‘kapalı’.",
+ "classesObjectDesc": "Algılanan nesneleri sınıflandırmak için farklı kategorileri tanımlayın. Örneğin: Bir kişi sınıflandırması için \"kurye\", \"bahçıvan\" veya \"yabancı\" olabilir.",
+ "classPlaceholder": "Sınıf ismi girin...",
+ "errors": {
+ "nameRequired": "Model ismi gereklidir",
+ "nameLength": "Model ismi en fazla 64 karakter olmalıdır",
+ "nameOnlyNumbers": "Model ismi yalnızca rakamlardan oluşamaz",
+ "classRequired": "En az 1 sınıf gereklidir",
+ "classesUnique": "Sınıf isimleri benzersiz olmalıdır",
+ "stateRequiresTwoClasses": "Durum modelleri en az 2 sınıf gerektirir",
+ "objectLabelRequired": "Lütfen bir nesne etiketi seçin",
+ "objectTypeRequired": "Lütfen bir sınıflandırma türü seçin",
+ "noneNotAllowed": "'none' sınıfına izin verilmiyor"
+ }
+ },
+ "step2": {
+ "description": "İzlenecek alanı her kamera için seçin ve tanımlayın. Model bu alanların durumunu sınıflandıracaktır.",
+ "cameras": "Kameralar",
+ "selectCamera": "Kamera Seç",
+ "noCameras": "Kameraları eklemek için + simgesine tıklayın",
+ "selectCameraPrompt": "Listedeki bir kamerayı seçerek izlenecek alanı tanımlayın"
+ },
+ "step3": {
+ "selectImagesPrompt": "{{className}} etiketli tüm görselleri seç",
+ "selectImagesDescription": "Görselleri seçmek için üzerlerine tıklayın. Bu sınıfla işiniz bittiğinde Devam Et’e tıklayın.",
+ "allImagesRequired_one": "Lütfen tüm görselleri sınıflandırın. Bir görsel kaldı.",
+ "allImagesRequired_other": "Lütfen tüm görselleri sınıflandırın. {{count}} görsel kaldı.",
+ "generating": {
+ "title": "Örnek Görseller Oluşturuluyor",
+ "description": "Frigate kayıtlarınızdan temsili görüntüler alınıyor. Bu işlem biraz zaman alabilir…"
+ },
+ "training": {
+ "title": "Model Eğitiliyor",
+ "description": "Modeliniz arka planda eğitiliyor. Bu pencereyi kapatabilirsiniz; eğitim tamamlandığında model otomatik olarak çalışmaya başlayacaktır."
+ },
+ "retryGenerate": "Oluşturmayı Yeniden Dene",
+ "noImages": "Örnek görsel oluşturulamadı",
+ "classifying": "Sınıflandırılıyor ve Eğitiliyor...",
+ "trainingStarted": "Eğitim başarıyla başlatıldı",
+ "modelCreated": "Model başarıyla oluşturuldu. Eksik durumlar için görseller eklemek üzere Son Sınıflandırmalar görünümünü kullanın ve ardından modeli eğitin.",
+ "errors": {
+ "noCameras": "Hiç kamera yapılandırılmadı",
+ "noObjectLabel": "Nesne etiketi seçilmedi",
+ "generateFailed": "Örnekler oluşturulamadı: {{error}}",
+ "generationFailed": "Oluşturma başarısız oldu. Lütfen tekrar deneyin.",
+ "classifyFailed": "Görseller sınıflandırılamadı: {{error}}"
+ },
+ "generateSuccess": "Örnek görseller başarıyla oluşturuldu",
+ "missingStatesWarning": {
+ "title": "Eksik Durum Örnekleri",
+ "description": "En iyi sonuçlar için her bir durum için örnek görseller seçmeniz tavsiye edilir. Tüm durumlar için görsel seçmeden devam edebilirsiniz fakat tüm durumlar için görseller seçilmedikçe model eğitilemeyecektir. Son Sınıflandırmalar arayüzünü kullanarak görselleri sınıflandırmak üzere görüntüleyebilir, yeterince görsel seçildikten sonra da modeli eğitebilirsiniz."
+ }
+ }
+ },
+ "none": "Yok"
+}
diff --git a/web/public/locales/tr/views/configEditor.json b/web/public/locales/tr/views/configEditor.json
index c4aa01b6b..32ffdb2cb 100644
--- a/web/public/locales/tr/views/configEditor.json
+++ b/web/public/locales/tr/views/configEditor.json
@@ -12,5 +12,7 @@
"configEditor": "Yapılandırma Düzenleyicisi",
"documentTitle": "Yapılandırma Düzenleyicisi - Frigate",
"saveAndRestart": "Kaydet & Yeniden Başlat",
- "confirm": "Kaydetmeden çıkılsın mı?"
+ "confirm": "Kaydetmeden çıkılsın mı?",
+ "safeConfigEditor": "Yapılandırma Düzenleyicisi (Güvenli Mod)",
+ "safeModeDescription": "Frigate, yapılandırmanızdaki bir hata nedeniyle güvenli moda geçti."
}
diff --git a/web/public/locales/tr/views/events.json b/web/public/locales/tr/views/events.json
index 3f363c70f..d0d30072a 100644
--- a/web/public/locales/tr/views/events.json
+++ b/web/public/locales/tr/views/events.json
@@ -1,11 +1,15 @@
{
"camera": "kamera",
- "alerts": "Alarmlar",
+ "alerts": "Uyarılar",
"detections": "Tespitler",
"empty": {
"detection": "İncelenecek tespit öğesi yok",
- "alert": "İncelenecek alarm öğesi yok",
- "motion": "Hareket verisi bulunamadı"
+ "alert": "İncelenecek uyarı öğesi yok",
+ "motion": "Hareket verisi bulunamadı",
+ "recordingsDisabled": {
+ "title": "Kayıt özelliği etkinleştirilmelidir",
+ "description": "İnceleme öğeleri yalnızca bir kamera için kayıt özelliği etkinleştirildiğinde oluşturulabilir."
+ }
},
"timeline": "Zaman şeridi",
"events": {
@@ -34,5 +38,30 @@
"allCameras": "Tüm Kameralar",
"selected_one": "{{count}} seçildi",
"selected_other": "{{count}} seçildi",
- "detected": "algılandı"
+ "detected": "algılandı",
+ "suspiciousActivity": "Şüpheli Etkinlik",
+ "threateningActivity": "Tehlikeli Etkinlik",
+ "zoomIn": "Büyüt",
+ "zoomOut": "Küçült",
+ "detail": {
+ "label": "Detay",
+ "aria": "Ayrıntı görünümünü aç/kapat",
+ "trackedObject_one": "{{count}} nesne",
+ "trackedObject_other": "{{count}} nesne",
+ "noObjectDetailData": "Nesneye ait ayrıntılı veri bulunmuyor.",
+ "settings": "Ayrıntılı Görünüm Ayarları",
+ "alwaysExpandActive": {
+ "title": "Etkin olanı her zaman genişlet",
+ "desc": "Varsa, etkin inceleme öğesinin nesne ayrıntılarını daima göster."
+ },
+ "noDataFound": "İncelenecek ayrıntılı veri bulunmuyor"
+ },
+ "objectTrack": {
+ "trackedPoint": "Takip edilen nokta",
+ "clickToSeek": "Bu zamana atlamak için tıklayın"
+ },
+ "normalActivity": "Normal",
+ "needsReview": "İnceleme Gerekiyor",
+ "securityConcern": "Güvenlik endişesi",
+ "select_all": "Tümü"
}
diff --git a/web/public/locales/tr/views/explore.json b/web/public/locales/tr/views/explore.json
index 485fe9b43..206e6ac96 100644
--- a/web/public/locales/tr/views/explore.json
+++ b/web/public/locales/tr/views/explore.json
@@ -10,7 +10,7 @@
"viewInExplore": "Keşfet'te Görüntüle"
},
"tips": {
- "hasMissingObjects": "Eğer Frigate'in {{objects}} etiketine sahip nesneleri kaydetmesini istiyorsanız yapılandırmanızı buna göre ayarlayın.",
+ "hasMissingObjects": "Eğer Frigate'in {{objects}} etiketine sahip nesneleri kaydetmesini istiyorsanız yapılandırmanızı buna göre ayarlayın",
"mismatch_one": "Tespit edilmiş olan bir nesne bu İncele öğesine dahil edildi. Bu nesne Alarm veya Tespit olarak derecelendirilemedi veya çoktan silindi/temizlendi.",
"mismatch_other": "Tespit edilmiş olan {{count}} adet nesne bu İncele öğesine dahil edildi. Bu nesneler Alarm veya Tespit olarak derecelendirilemedi veya çoktan silindi/temizlendi."
},
@@ -18,12 +18,16 @@
"success": {
"updatedSublabel": "Alt etiket başarıyla gücellendi.",
"regenerate": "Yeni bir açıklama {{provider}} sağlayıcısından talep edildi. Sağlayıcının hızına bağlı olarak yeni açıklamanın oluşturulması biraz zaman alabilir.",
- "updatedLPR": "Plaka başarıyla güncellendi."
+ "updatedLPR": "Plaka başarıyla güncellendi.",
+ "audioTranscription": "Ses dökümü başarıyla istendi. Frigate sunucunuzun hızına bağlı olarak döküm işlemi tamamlanması biraz zaman alabilir.",
+ "updatedAttributes": "Özellikler başarıyla güncellendi."
},
"error": {
"updatedSublabelFailed": "Alt etiket güncellenemedi: {{errorMessage}}",
"regenerate": "{{provider}} sağlayıcısından yeni açıklama talep edilemedi: {{errorMessage}}",
- "updatedLPRFailed": "Plaka güncellenemedi: {{errorMessage}}"
+ "updatedLPRFailed": "Plaka güncellenemedi: {{errorMessage}}",
+ "audioTranscription": "Ses çözümlemesi talep edilemedi: {{errorMessage}}",
+ "updatedAttributesFailed": "Özellikler güncellenemedi: {{errorMessage}}"
}
}
},
@@ -68,6 +72,17 @@
"recognizedLicensePlate": "Tanınan Plaka",
"snapshotScore": {
"label": "Fotoğraf Skoru"
+ },
+ "score": {
+ "label": "Skor"
+ },
+ "editAttributes": {
+ "title": "Özellikleri düzenle",
+ "desc": "Bu {{label}} için sınıflandırma özelliklerini seçin"
+ },
+ "attributes": "Sınıflandırma Özellikleri",
+ "title": {
+ "label": "Başlık"
}
},
"generativeAI": "Üretken Yapay Zeka",
@@ -102,12 +117,14 @@
"trackedObjectDetails": "Takip Edilen Nesne Detayları",
"type": {
"details": "detaylar",
- "object_lifecycle": "nesne geçmişi",
+ "object_lifecycle": "nesne yaşam döngüsü",
"snapshot": "fotoğraf",
- "video": "video"
+ "video": "video",
+ "thumbnail": "küçük resim",
+ "tracking_details": "izleme ayrıntıları"
},
"objectLifecycle": {
- "title": "Nesne Geçmişi",
+ "title": "Nesne Yaşam Döngüsü",
"noImageFound": "Bu zaman damgası için bir resim bulunamadı.",
"createObjectMask": "Nesne Maskesi Oluştur",
"adjustAnnotationSettings": "Belirteç ayarları",
@@ -150,7 +167,7 @@
"next": "Sonraki sayfa",
"previous": "Önceki sayfa"
},
- "scrollViewTips": "Bu nesnenin geçmişindeki önemli noktaları görmek için kaydırın.",
+ "scrollViewTips": "Bu nesnenin yaşam döngüsündeki önemli noktaları görmek için kaydırın.",
"autoTrackingTips": "Otomatik takip yapılan kameralarda gösterilen çerçeveler hatalı olacaktır.",
"count": "Toplam {{second}} kerede {{first}} kez",
"trackedPoint": "Takip Edilen Nokta"
@@ -182,6 +199,28 @@
"downloadSnapshot": {
"aria": "Fotoğrafı indir",
"label": "Fotoğrafı indir"
+ },
+ "addTrigger": {
+ "label": "Tetik ekle",
+ "aria": "Bu takip edilen nesne için bir tetik ekle"
+ },
+ "audioTranscription": {
+ "label": "Çözümle",
+ "aria": "Ses çözümlemesi iste"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Temiz anlık görüntüyü indir",
+ "aria": "Temiz anlık görüntüyü indir"
+ },
+ "viewTrackingDetails": {
+ "label": "Takip ayrıntılarını görüntüle",
+ "aria": "Takip ayrıntılarını göster"
+ },
+ "showObjectDetails": {
+ "label": "Nesne yolunu göster"
+ },
+ "hideObjectDetails": {
+ "label": "Nesne yolunu gizle"
}
},
"noTrackedObjects": "Takip Edilen Nesne Bulunamadı",
@@ -193,15 +232,72 @@
"success": "Takip edilen nesne başarıyla silindi."
}
},
- "tooltip": "Eşleşme: {{type}} (%{{confidence}})"
+ "tooltip": "Eşleşme: {{type}} (%{{confidence}})",
+ "previousTrackedObject": "Önceki izlenen nesne",
+ "nextTrackedObject": "Sonraki izlenen nesne"
},
"dialog": {
"confirmDelete": {
- "desc": "Bu takip edilen nesneyi silmek nesne fotoğrafını, ilişkili gömüyü ve ilişkili yaşam döngüsü kayıtlarını siler. Video kayıt görüntüleri geçmiş görünümünden SİLİNMEYECEKTİR.
Devam etmek istediğinize emin misiniz?",
+ "desc": "Bu takip edilen nesneyi silmek anlık görüntüyü, kaydedilmiş gömü verilerini ve ilişkili yaşam döngüsü kayıtlarını siler. Geçmiş görünümündeki bu izlenen nesneye ait kayıtlı video görüntüleri SİLİNMEYECEKTİR.
Devam etmek istediğinizden emin misiniz?",
"title": "Silmeyi onayla"
}
},
"trackedObjectsCount_one": "{{count}} adet takip edilen nesne ",
"trackedObjectsCount_other": "{{count}} adet takip edilen nesne ",
- "exploreMore": "Daha fazla {{label}} nesnesini keşfet"
+ "exploreMore": "Daha fazla {{label}} nesnesini keşfet",
+ "aiAnalysis": {
+ "title": "Yapay Zeka Analizi"
+ },
+ "trackingDetails": {
+ "title": "Takip Ayrıntıları",
+ "noImageFound": "Bu zaman damgasına ait bir görsel bulunamadı.",
+ "createObjectMask": "Nesne Maskesi Oluştur",
+ "adjustAnnotationSettings": "Etiketleme ayarlarını düzenle",
+ "scrollViewTips": "Bu nesnenin yaşam döngüsündeki önemli olayları görmek için tıklayın.",
+ "autoTrackingTips": "Otomatik takip yapan kameralar için sınır kutusu konumları doğru olmayabilir.",
+ "count": "{{second}}’den {{first}}",
+ "trackedPoint": "Takip edilen nokta",
+ "lifecycleItemDesc": {
+ "visible": "{{label}} tespit edildi",
+ "entered_zone": "{{label}}, {{zones}} bölgesine girdi",
+ "active": "{{label}} etkin hale geldi",
+ "stationary": "{{label}} sabit hale geldi",
+ "attribute": {
+ "faceOrLicense_plate": "{{label}} için {{attribute}} tespit edildi",
+ "other": "{{label}}, {{attribute}} olarak tanındı"
+ },
+ "gone": "{{label}} ayrıldı",
+ "heard": "{{label}} duyuldu",
+ "external": "{{label}} tespit edildi",
+ "header": {
+ "zones": "Bölgeler",
+ "ratio": "Oran",
+ "area": "Alan",
+ "score": "Skor"
+ }
+ },
+ "annotationSettings": {
+ "title": "Etiketleme Ayarları",
+ "showAllZones": {
+ "title": "Tüm Bölgeleri Göster",
+ "desc": "Herhangi bir bölgeye nesne girdiğinde, o karede bölgeleri her zaman göster."
+ },
+ "offset": {
+ "label": "Etiket Kaydırma Değeri",
+ "desc": "Bu veriler kameranızın algılama akışından gelir ancak kayıt akışındaki görüntülerin üzerine bindirilir. İki akış tamamen eşzamanlı olmayabilir, bu durum da sınır kutusu ile görüntünün hizasını kaydırabilir. Bu ayarı kullanarak zaman senkronunu ileri veya geri kaydırarak kayıt akışını ve etiketlemeleri hizalayabilirsiniz.",
+ "millisecondsToOffset": "Algılama etiketlemelerinin kaydırılacağı milisaniye değeri. Varsayılan: 0",
+ "tips": "Videonun oynatımı kutulardan ve yol noktalarından öndeyse değeri düşürün; geride kalıyorsa değeri artırın. Bu değer negatif olabilir.",
+ "toast": {
+ "success": "{{camera}} için etiketleme zaman kaydırması yapılandırma dosyasına kaydedildi."
+ }
+ }
+ },
+ "carousel": {
+ "previous": "Önceki slayt",
+ "next": "Sonraki slayt"
+ }
+ },
+ "concerns": {
+ "label": "Endişeler"
+ }
}
diff --git a/web/public/locales/tr/views/exports.json b/web/public/locales/tr/views/exports.json
index 3a1d19512..0c8fec129 100644
--- a/web/public/locales/tr/views/exports.json
+++ b/web/public/locales/tr/views/exports.json
@@ -13,5 +13,11 @@
"renameExportFailed": "Dışa aktarım adlandırılamadı: {{errorMessage}}"
}
},
- "noExports": "Dışa aktarım bulunamadı"
+ "noExports": "Dışa aktarım bulunamadı",
+ "tooltip": {
+ "shareExport": "Dışa aktarmayı paylaş",
+ "downloadVideo": "Videoyu İndir",
+ "editName": "İsmi Düzenle",
+ "deleteExport": "Dışa Aktarmayı Sil"
+ }
}
diff --git a/web/public/locales/tr/views/faceLibrary.json b/web/public/locales/tr/views/faceLibrary.json
index 428d6eaf2..6df04530b 100644
--- a/web/public/locales/tr/views/faceLibrary.json
+++ b/web/public/locales/tr/views/faceLibrary.json
@@ -2,8 +2,8 @@
"selectItem": "{{item}} seçin",
"description": {
"placeholder": "Bu koleksiyona bir isim verin",
- "addFace": "Yüz Kütüphanesi’ne yeni bir koleksiyon ekleme adımlarını takip edin.",
- "invalidName": "Geçersiz isim. İsimlerde yalnızca harf, sayı, boşluk, kesme işareti, tire veya alt çizgi kullanılabilir."
+ "addFace": "İlk görselinizi yükleyerek Yüz Kütüphanesi’ne yeni bir koleksiyon ekleyin.",
+ "invalidName": "Geçersiz isim. İsimler; yalnızca harf, rakam, boşluk, kesme işareti (’), alt çizgi(_) ve tire (-) içerebilir."
},
"details": {
"person": "İnsan",
@@ -13,7 +13,7 @@
"face": "Yüz Detayları",
"scoreInfo": "Alt etiket skoru, tanınan tüm yüzlerin güvenilirlik değerlerinin ağırlıklı ortalamasından elde edilir, dolayısıyla fotoğraf üzerinde gösterilen skordan farklı olabilir.",
"subLabelScore": "Alt Etiket Puanı",
- "unknown": "Bilinmeyen"
+ "unknown": "Bilinmiyor"
},
"documentTitle": "Yüz Kütüphanesi - Frigate",
"uploadFaceImage": {
@@ -24,12 +24,13 @@
"desc": "Yeni bir yüz koleksiyonu oluşturun",
"new": "Yeni Yüz Oluştur",
"title": "Koleksiyon Oluştur",
- "nextSteps": "Sağlam bir temel oluşturmak için:Her tespit edilen kişi için 'Eğit' sekmesinden resimler seçip eğitin. En iyi sonuçlar için doğrudan karşıdan çekilmiş yüz resimlerine odaklanın; açılı yüz resimlerinden kaçının. "
+ "nextSteps": "Sağlam bir temel oluşturmak için:Her tespit edilen kişi için **Recent Recognitions (Son Tanımalar)** sekmesini kullanarak görüntüleri seçin ve eğitim gerçekleştirin. En iyi sonuçlar için doğrudan önden çekilmiş yüz görüntülerine odaklanın; yüzlerin açılı göründüğü fotoğrafları eğitimde kullanmaktan kaçının. "
},
"train": {
- "title": "Eğit",
- "aria": "Eğitimi seç",
- "empty": "Yakın zamanda yüz tanıma denemesi olmadı"
+ "title": "Son Tanımalar",
+ "aria": "Son algılanan nesneleri seç",
+ "empty": "Yakın zamanda yüz tanıma denemesi olmadı",
+ "titleShort": "Son"
},
"deleteFaceLibrary": {
"title": "İsmi Sil",
@@ -49,7 +50,7 @@
"validation": {
"selectImage": "Lütfen bir resim dosyası seçin."
},
- "dropInstructions": "Bir resmi buraya sürükleyip bırakın ya da tıklayarak seçin"
+ "dropInstructions": "Bir görseli buraya sürükleyip bırakın, yapıştırın ya da seçmek için tıklayın"
},
"trainFaceAs": "Yüzü şu olarak eğit:",
"toast": {
@@ -61,7 +62,7 @@
"addFaceLibrary": "{{name}} başarıyla Yüz Kütüphanesi’ne eklendi!",
"trainedFace": "Yüz başarıyla eğitildi.",
"uploadedImage": "Resim başarıyla yüklendi.",
- "updatedFaceScore": "Yüz skoru başarıyla güncellendi.",
+ "updatedFaceScore": "Yüz tanıma skoru {{name}} ({{score}}) olarak başarıyla güncellendi.",
"renamedFace": "Yüz başarıyla {{name}} olarak adlandırıldı"
},
"error": {
@@ -82,7 +83,7 @@
"uploadFace": "Yüz Resmi Yükle",
"nextSteps": "Sonraki Adımlar",
"description": {
- "uploadFace": "{{name}}'ın yüzünü direkt karşıdan, ön açıdan gösteren bir fotoğraf yükleyin. Fotoğrafı yalnızca yüzü kalacak şekilde kırpmanıza gerek YOKTUR."
+ "uploadFace": "{{name}}'in yüzünü önden gösteren bir fotoğraf yükleyin. Fotoğrafın sadece yüzünü gösterecek şekilde kırpılması gerekmez."
}
},
"renameFace": {
diff --git a/web/public/locales/tr/views/live.json b/web/public/locales/tr/views/live.json
index 88f040856..60a8576ff 100644
--- a/web/public/locales/tr/views/live.json
+++ b/web/public/locales/tr/views/live.json
@@ -10,7 +10,7 @@
"enable": "Otomatik Takibi Aç"
},
"manualRecording": {
- "start": "Talep üzerine kaydı başlat",
+ "start": "Talep Üzerine Kaydı Başlat",
"failedToEnd": "Manuel talep üzerine kayıt bitirilemedi.",
"recordDisabledTips": "Kamera konfigürasyonunda kayıtlar devre dışı bırakıldığı veya kısıtlandığı için yalnızca bir fotoğraf kaydedilcektir.",
"showStats": {
@@ -19,11 +19,11 @@
},
"started": "Manuel talep üzerine kayıt başlatıldı.",
"failedToStart": "Manuel talep üzerine kayıt başlatılamadı.",
- "title": "İsteğe Bağlı Kayıt",
- "end": "Talep üzerine kaydı bitir",
+ "title": "İsteğe Bağlı",
+ "end": "Talep Üzerine Kaydı Bitir",
"debugView": "Hata Ayıklama Görünümü",
"ended": "Manuel talep üzerine kayıt bitirildi.",
- "tips": "Bu kameranın kayıt tutma ayarları kapsamında manuel olarak bir olay başlatın.",
+ "tips": "Bu kameranın kayıt saklama ayarlarına göre anlık bir görüntü indirin veya manuel bir olay başlatın.",
"playInBackground": {
"label": "Arka planda oynat",
"desc": "Yayını oynatıcı arkadayken de devam ettirmek için bu seçeneği açın."
@@ -52,7 +52,10 @@
"label": "Arka planda oynat",
"tips": "Yayını oynatıcı arkadayken de devam ettirmek için bu seçeneği açın."
},
- "title": "Yayın"
+ "title": "Yayın",
+ "debug": {
+ "picker": "Hata ayıklama modunda akış seçimi kullanılamaz. Hata ayıklama görünümü her zaman tespit(detect) rolüne atanmış akışı kullanır."
+ }
},
"cameraSettings": {
"recording": "Kayıt",
@@ -60,8 +63,9 @@
"title": "{{camera}} Ayarları",
"autotracking": "Otomatik Takip",
"cameraEnabled": "Kamera Açık",
- "objectDetection": "Nesne Algılama",
- "audioDetection": "Ses Algılama"
+ "objectDetection": "Nesne Tespiti",
+ "audioDetection": "Ses Algılama",
+ "transcription": "Ses Çözümlemesi"
},
"effectiveRetainMode": {
"modes": {
@@ -115,14 +119,22 @@
"center": {
"label": "PTZ kamerayı ortalamak için görüntüye tıklatın"
}
+ },
+ "focus": {
+ "in": {
+ "label": "PTZ kamera odağını yakınlaştır"
+ },
+ "out": {
+ "label": "PTZ kamera odağını uzaklaştır"
+ }
}
},
"history": {
"label": "Geçmiş görüntüleri göster"
},
"camera": {
- "enable": "Kamerayı aç",
- "disable": "Kamerayı kapat"
+ "enable": "Kamerayı Aç",
+ "disable": "Kamerayı Kapat"
},
"suspend": {
"forTime": "Askıya alınma süresi: "
@@ -154,5 +166,34 @@
"detect": {
"disable": "Tespiti Kapat",
"enable": "Tespiti Aç"
+ },
+ "transcription": {
+ "enable": "Canlı Ses Çözümlemeyi Aç",
+ "disable": "Canlı Ses Çözümlemeyi Kapat"
+ },
+ "snapshot": {
+ "takeSnapshot": "Anlık görüntüyü indir",
+ "noVideoSource": "Anlık görüntü için kullanılabilir bir video kaynağı bulunamadı.",
+ "captureFailed": "Anlık görüntü yakalanamadı.",
+ "downloadStarted": "Anlık görüntü indirme işlemi başlatıldı."
+ },
+ "noCameras": {
+ "title": "Yapılandırılmış Kamera Yok",
+ "description": "Frigate’e bir kamera bağlayarak başlayın.",
+ "buttonText": "Kamera Ekle",
+ "restricted": {
+ "title": "Kullanılabilir Kamera Yok",
+ "description": "Bu gruptaki kameraları görüntüleme izniniz yok."
+ },
+ "default": {
+ "title": "Hiçbir kamera yapılandırılmamış",
+ "description": "Öncelikle bir kamerayı Frigate'e bağlayarak başlayın.",
+ "buttonText": "Kamera Ekle"
+ },
+ "group": {
+ "title": "Grupta Kamera Yok",
+ "description": "Bu kamera grubuna atanmış veya etkinleştirilmiş kamera bulunmamaktadır.",
+ "buttonText": "Grupları Yönet"
+ }
}
}
diff --git a/web/public/locales/tr/views/search.json b/web/public/locales/tr/views/search.json
index 059023308..2de2edf47 100644
--- a/web/public/locales/tr/views/search.json
+++ b/web/public/locales/tr/views/search.json
@@ -19,11 +19,12 @@
"time_range": "Zaman Aralığı",
"before": "Önce",
"zones": "Alanlar",
- "after": "Sonras",
+ "after": "Sonra",
"has_clip": "Klibi var",
"min_speed": "Min. Hız",
"sub_labels": "Alt Etiketler",
- "max_speed": "Maks. Hız"
+ "max_speed": "Maks. Hız",
+ "attributes": "Özellikler"
},
"searchType": {
"description": "Açıklama",
diff --git a/web/public/locales/tr/views/settings.json b/web/public/locales/tr/views/settings.json
index 590702370..3d419144f 100644
--- a/web/public/locales/tr/views/settings.json
+++ b/web/public/locales/tr/views/settings.json
@@ -8,9 +8,11 @@
"motionTuner": "Hareket Algılama Ayarları - Frigate",
"frigatePlus": "Frigate+ Ayarları - Frigate",
"object": "Hata Ayıklama - Frigate",
- "general": "Genel Ayarlar - Frigate",
+ "general": "Kullanıcı Arayüzü Ayarları – Frigate",
"notifications": "Bildirim Ayarları - Frigate",
- "enrichments": "Zenginleştirme Ayarları - Frigate"
+ "enrichments": "Zenginleştirme Ayarları - Frigate",
+ "cameraManagement": "Kameraları Yönet - Frigate",
+ "cameraReview": "Kamera İnceleme Ayarları - Frigate"
},
"menu": {
"masksAndZones": "Maskeler / Alanlar",
@@ -22,10 +24,14 @@
"classification": "Sınıflandırma",
"debug": "Hata Ayıklama",
"cameras": "Kamera Ayarları",
- "enrichments": "Zenginleştirmeler"
+ "enrichments": "Zenginleştirmeler",
+ "triggers": "Tetikler",
+ "cameraManagement": "Yönetim",
+ "cameraReview": "İncele",
+ "roles": "Roller"
},
"general": {
- "title": "Genel Ayarlar",
+ "title": "Kullanıcı Arayüzü Ayarları",
"liveDashboard": {
"automaticLiveView": {
"label": "Otomatik Canlı Görünüm",
@@ -33,9 +39,17 @@
},
"playAlertVideos": {
"label": "Alarm Videolarını Oynat",
- "desc": "Varsayılan olarak canlı görüntü panelinde gösterilen son alarmlar ufak videolar olarak oynatılır. Bu tarayıcı/cihazda video yerine sabit resim göstermek için bu seçeneği kapatın."
+ "desc": "Varsayılan olarak canlı görüntü panelinde gösterilen son uyarılar ufak videolar olarak oynatılır. Bu tarayıcı/cihazda video yerine sabit resim göstermek için bu seçeneği kapatın."
},
- "title": "Canlı Görüntü Paneli"
+ "title": "Canlı Görüntü Paneli",
+ "displayCameraNames": {
+ "label": "Kamera Adlarını Daima Göster",
+ "desc": "Çok kameralı canlı izleme panelinde, kamera adlarını her zaman bir etiket içinde göster."
+ },
+ "liveFallbackTimeout": {
+ "label": "Canlı Oynatıcı Yedeğe Geçiş Zaman Aşımı",
+ "desc": "Bir kameranın yüksek kaliteli canlı akışı kullanılamadığında, belirtilen saniye kadar sonra düşük bant genişliği moduna geç. Varsayılan: 3."
+ }
},
"storedLayouts": {
"desc": "Kamera grubundaki kameraların düzenini kameraları sürükleyerek ve büyüterek/küçülterek değiştirebilirsiniz. Düzen bilgisi tarayıcınızda depolanır.",
@@ -177,6 +191,44 @@
"streams": {
"desc": "Frigate yeniden başlataılana kadar bir kamerayı devre dışı bırakın. Bir kameranın devre dışı bırakılması, Frigate'in bu kamerayı işlemesini tamamen durdurur. Algılama, kayıt ve hata ayıklama özellikleri kullanılamaz.
Not: Bu eylem, go2rtc'deki yeniden akışları devre dışı bırakmaz.",
"title": "Akışlar"
+ },
+ "object_descriptions": {
+ "title": "Üretken AI Nesne Açıklamaları",
+ "desc": "Bu kamera için Üretken Yapay Zeka kullanarak nesne açıklamaları oluşturmayı geçici olarak etkinleştirin/devre dışı bırakın. Devre dışı bırakıldığında, bu kamerada takip edilen nesneler için yapay zekadan nesne açıklamaları talep edilmeyecektir."
+ },
+ "review_descriptions": {
+ "title": "Üretken AI İnceleme Öğesi Açıklamaları",
+ "desc": "Bu kamera için Üretken Yapay Zeka kullanarak inceleme öğelerinin açıklamalarını oluşturmayı geçici olarak etkinleştirin/devre dışı bırakın. Devre dışı bırakıldığında, bu kameraya bağlı inceleme öğeleri için yapay zekadan açıklama metni talep edilmeyecektir."
+ },
+ "addCamera": "Yeni Kamera Ekle",
+ "editCamera": "Kamerayı Düzenle:",
+ "selectCamera": "Kamera Seç",
+ "backToSettings": "Kamera Ayarlarına Dön",
+ "cameraConfig": {
+ "add": "Kamera Ekle",
+ "edit": "Kamerayı Düzenle",
+ "description": "Kameranızın ayarlarını, kameraların akışları ve roller de dahil olacak şekilde yapılandırın.",
+ "name": "Kamera İsmi",
+ "nameRequired": "Kamera adı gereklidir",
+ "nameInvalid": "Kamera adı yalnızca harf, rakam, alt çizgi veya tire içerebilir",
+ "namePlaceholder": "örn: onkapi",
+ "enabled": "Açık",
+ "ffmpeg": {
+ "inputs": "Kamera Girdi Akışları",
+ "path": "Akış Yolu",
+ "pathRequired": "Akış yolu gereklidir",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Roller",
+ "rolesRequired": "En az bir rol gereklidir",
+ "rolesUnique": "Her rol (ses, tespit, kayıt) yalnızca bir adet yayına atanabilir. Her rol aynı akışı kullanabilir, lakin bir rol birden fazla akışa atanamaz.",
+ "addInput": "Girdi Akışı Ekle",
+ "removeInput": "Girdi Akışını Kaldır",
+ "inputsRequired": "En az bir girdi akışı gereklidir"
+ },
+ "toast": {
+ "success": "Kamera {{cameraName}} başarıyla kaydedildi"
+ },
+ "nameLength": "Kamera ismi 24 karakterden kısa olmalıdır."
}
},
"masksAndZones": {
@@ -198,7 +250,8 @@
"hasIllegalCharacter": "Alan adı geçersiz karakterler içeriyor.",
"mustNotBeSameWithCamera": "Alan adı kamera adıyla aynı olmamalıdır.",
"alreadyExists": "Bu kamera için bu ada sahip bir alan zaten mevcut.",
- "mustNotContainPeriod": "Alan adı nokta içermemelidir."
+ "mustNotContainPeriod": "Alan adı nokta içermemelidir.",
+ "mustHaveAtLeastOneLetter": "Bölge ismi en az bir harf içermelidir."
}
},
"distance": {
@@ -254,7 +307,7 @@
"name": {
"inputPlaceHolder": "Bir isim girin…",
"title": "İsim",
- "tips": "Ad en az 2 karakter olmalı ve bir kamera veya başka bir bölgenin adı olmamalıdır."
+ "tips": "İsim 2 karakter veya daha uzun olmalı, en az bir harf içermeli ve bu kameradaki bir kamera ismi veya başka bir bölge ismiyle çakışmamalıdır."
},
"inertia": {
"title": "Eylemsizlik",
@@ -290,7 +343,7 @@
"title": "Hız Alt Sınırı ({{unit}})"
},
"toast": {
- "success": "Alan ({{zoneName}}) kaydedildi. Değişiklikleri uygulamak için Frigate'i yeniden başlatın."
+ "success": "Bölge ({{zoneName}}) kaydedildi."
},
"allObjects": "Bütün Nesneler"
},
@@ -310,8 +363,8 @@
},
"toast": {
"success": {
- "title": "{{polygonName}} kaydedildi. Değişiklikleri uygulamak için Frigate'i yeniden başlatın.",
- "noName": "Hareket Maskesi kaydedildi. Değişiklikleri uygulamak için Frigate'i yeniden başlatın."
+ "title": "{{polygonName}} kaydedildi.",
+ "noName": "Hareket Maskesi kaydedildi."
}
},
"desc": {
@@ -339,8 +392,8 @@
"edit": "Nesne Maskesini Düzenle",
"toast": {
"success": {
- "noName": "Nesne Maskesi kaydedildi. Değişiklikleri uygulamak için Frigate'i yeniden başlatın.",
- "title": "{{polygonName}} kaydedildi. Değişiklikleri uygulamak için Frigate'i yeniden başlatın."
+ "noName": "Nesne Maskesi kaydedildi.",
+ "title": "{{polygonName}} kaydedildi."
}
},
"documentTitle": "Nesne Maskesini Düzenle - Frigate",
@@ -396,7 +449,7 @@
"regions": {
"title": "Tespit Bölgeleri",
"desc": "Nesne algılayıcıya gönderilen tespit alanlarını göster",
- "tips": "Bölge Kutuları
Görüntüdeki nesne dedektörüne gönderilen tespit alanları parlak yeşil renk çerçeve ile gösterilir.
"
+ "tips": "Bölge Kutuları
Nesne dedektörüne gönderilen tespit alanları görüntüde parlak yeşil renk çerçeve ile gösterilir.
"
},
"objectShapeFilterDrawing": {
"title": "Nesne Şekil Filtresi Çizimi",
@@ -419,7 +472,20 @@
"desc": "Tanımlanmış alanların sınırlarını göster"
},
"objectList": "Nesne Listesi",
- "desc": "Hata ayıklama görünümü, izlenen nesnelerin ve istatistiklerinin gerçek zamanlı bir görünümünü gösterir. Nesne listesi algılanan nesnelerin zaman gecikmeli bir özetini gösterir."
+ "desc": "Hata ayıklama görünümü, izlenen nesnelerin ve istatistiklerinin gerçek zamanlı bir görünümünü gösterir. Nesne listesi algılanan nesnelerin zaman gecikmeli bir özetini gösterir.",
+ "paths": {
+ "title": "Hareket İzi",
+ "desc": "Takip edilen nesnenin hareket izi üzerindeki önemli noktaları göster",
+ "tips": "Hareket İzi
Çizgiler ve daireler, takip edilen nesnenin yaşam döngüsü boyunca hareket ettiği önemli noktaları gösterir.
"
+ },
+ "openCameraWebUI": "{{camera}}'nın Web Arayüzünü Aç",
+ "audio": {
+ "title": "Ses",
+ "noAudioDetections": "Ses tespiti yok",
+ "score": "skor",
+ "currentRMS": "Şu Anki RMS",
+ "currentdbFS": "Şu Anki dbFS"
+ }
},
"users": {
"title": "Kullanıcılar",
@@ -449,7 +515,7 @@
"changeRole": "Kullanıcı rolünü değiştir",
"deleteUser": "Kullanıcıyı sil",
"role": "Rol",
- "password": "Parola"
+ "password": "Parola Sıfırla"
},
"dialog": {
"form": {
@@ -473,7 +539,16 @@
"veryStrong": "Çok Güçlü"
},
"notMatch": "Parolalar eşleşmiyor",
- "match": "Parolalar eşleşiyor"
+ "match": "Parolalar eşleşiyor",
+ "show": "Parolay⁸ göster",
+ "hide": "Parolayı gizle",
+ "requirements": {
+ "title": "Parola gereksinimleri:",
+ "length": "En az 8 karakter",
+ "uppercase": "En az bir büyük harf",
+ "digit": "En az bir rakam",
+ "special": "En az bir özel karakter (!@#$%^&*(),.?\":{}|<>)"
+ }
},
"newPassword": {
"placeholder": "Yeni parola girin",
@@ -483,7 +558,11 @@
"title": "Yeni Parola"
},
"usernameIsRequired": "Kullanıcı adı gereklidir",
- "passwordIsRequired": "Parola gereklidir"
+ "passwordIsRequired": "Parola gereklidir",
+ "currentPassword": {
+ "title": "Mevcut Parola",
+ "placeholder": "Mevcut parolanızı girin"
+ }
},
"createUser": {
"title": "Yeni Kullanıcı Oluştur",
@@ -501,7 +580,12 @@
"setPassword": "Parola Belirle",
"desc": "Bu hesabı güvenli hale getirmek güçlü bir parola belirleyin.",
"cannotBeEmpty": "Parola boş olamaz",
- "doNotMatch": "Parolalar eşleşmiyor"
+ "doNotMatch": "Parolalar eşleşmiyor",
+ "currentPasswordRequired": "Mevcut parola gereklidir",
+ "incorrectCurrentPassword": "Mevcut parola yanlış",
+ "passwordVerificationFailed": "Parola doğrulanamadı",
+ "multiDeviceWarning": "Oturum açtığınız diğer tüm cihazların {{refresh_time}} süresi içinde yeniden oturum açması gerekecektir.",
+ "multiDeviceAdmin": "JWT gizli anahtarınızı yenileyerek tüm kullanıcıları derhal yeniden doğrulama yapmaya zorlayabilirsiniz."
},
"changeRole": {
"title": "Kullanıcı Rolünü Değiştir",
@@ -511,12 +595,13 @@
"intro": "Bu kullanıcı için bir rol seçin:",
"admin": "Yönetici",
"viewer": "Görüntüleyici",
- "viewerDesc": "Yalnızca Canlı, İncele, Keşfet ve Dışa Aktar'a girebilir."
+ "viewerDesc": "Yalnızca Canlı, İncele, Keşfet ve Dışa Aktar'a girebilir.",
+ "customDesc": "Belirli kamera erişimine sahip özel rol."
},
"select": "Bir rol seçin"
}
},
- "updatePassword": "Parola Belirle"
+ "updatePassword": "Parola Sıfırla"
},
"notification": {
"title": "Bildirimler",
@@ -528,7 +613,7 @@
"notificationUnavailable": {
"title": "Bildirimler Kullanılamıyor",
"documentation": "Dökümantasyonu Oku",
- "desc": "Web push bildirimleri güvenli bağlantı (https://…) gerektirir. Bu tarayıcınızın bir sınırlandırmasıdır. Bildirimleri kullanmak için Frigate arayüzüne HTTPS ile erişin."
+ "desc": "Web push bildirimleri güvenli bir bağlam gerektirir (https://…). Bu, tarayıcı sınırlamasıdır. Bildirimleri kullanmak için Frigate'e güvenli bir şekilde (https) erişin."
},
"globalSettings": {
"title": "Genel Ayarlar",
@@ -679,5 +764,454 @@
"success": "Zenginleştirme ayarları kaydedildi. Değişiklikleri uygulamak için Frigate'i yeniden başlatın.",
"error": "Yapılandırma değişiklikleri kaydedilemedi: {{errorMessage}}"
}
+ },
+ "triggers": {
+ "dialog": {
+ "form": {
+ "name": {
+ "error": {
+ "invalidCharacters": "Girdi yalnızca harf, rakam, alt çizgi ve tire içerebilir.",
+ "minLength": "Girdi en az 2 karakter uzunluğunda olmalıdır.",
+ "alreadyExists": "Bu kamerada aynı isimle bir tetik zaten mevcut."
+ },
+ "title": "İsim",
+ "placeholder": "Bu tetikleyiciye isim verin",
+ "description": "Bu tetikleyiciyi tanımlamak için benzersiz bir isim veya açıklama girin"
+ },
+ "enabled": {
+ "description": "Bu tetiği açın veya kapatın"
+ },
+ "type": {
+ "title": "Tetik Türü",
+ "placeholder": "Tetik türünü seçin",
+ "description": "Benzer izlenen nesne açıklaması algılandığında tetiklenir",
+ "thumbnail": "Benzer izlenen nesne küçük resmi algılandığında tetiklenir"
+ },
+ "content": {
+ "title": "İçerik",
+ "imagePlaceholder": "Bir küçük resim seçin",
+ "textPlaceholder": "Metin içeriği girin",
+ "imageDesc": "Yalnızca en son 100 küçük resim görüntülenir. İstediğiniz küçük resmi bulamazsanız, lütfen Keşfet bölümündeki önceki nesneleri inceleyin ve oradaki menüden bir tetikleyici ayarlayın.",
+ "textDesc": "Benzer bir takip edilen nesne açıklaması algılandığında bu eylemi tetiklemek için metin girin.",
+ "error": {
+ "required": "İçerik gereklidir."
+ }
+ },
+ "threshold": {
+ "title": "Tetik Eşiği",
+ "error": {
+ "min": "Tetik eşiği 0 ile 1 arasında olmalıdır",
+ "max": "Tetik eşiği 0 ile 1 arasında olmalıdır"
+ },
+ "desc": "Bu tetikleyici için benzerlik eşiğini ayarlayın. Daha yüksek bir eşik, tetiği tetiklemek için daha yakın bir eşleşme gerektiği anlamına gelir."
+ },
+ "actions": {
+ "title": "Eylemler",
+ "desc": "Varsayılan olarak, Frigate tüm tetikleyici isimlerini bir MQTT mesajı olarak gönderir. Alt etiketler, tetikleyici ismini nesne etiketine ekler. Nitelikler, izlenen nesne meta verilerinde ayrı olarak depolanan aranabilir meta verilerdir.",
+ "error": {
+ "min": "En az bir eylem seçilmelidir."
+ }
+ }
+ },
+ "createTrigger": {
+ "title": "Tetik Oluştur",
+ "desc": "{{camera}} kamerası için tetik oluşturun"
+ },
+ "editTrigger": {
+ "title": "Tetiği Düzenle",
+ "desc": "{{camera}} kamerasındaki tetiğin ayarlarını düzenleyin"
+ },
+ "deleteTrigger": {
+ "title": "Tetiği Sil",
+ "desc": "{{triggerName}} isimli tetiği silmek istediğinizden emin misiniz? Bu işlem geri alınamaz."
+ }
+ },
+ "documentTitle": "Tetikler",
+ "management": {
+ "title": "Tetikleyiciler",
+ "desc": "{{camera}} için tetikleri yönetin. Seçtiğiniz takip edilen nesneye benzer küçük resimlerde tetiklemek için küçük resmi kullanın veya belirlediğiniz metne benzer açıklamalar çıkması durumunda tetiklemek için ise açıklama seçeneğini kullanın."
+ },
+ "addTrigger": "Tetik Ekle",
+ "table": {
+ "name": "İsim",
+ "type": "Tetik Türü",
+ "content": "İçerik",
+ "threshold": "Tetik Eşiği",
+ "actions": "Eylemler",
+ "noTriggers": "Bu kamera için hiç bir tetik ayarlanmadı.",
+ "edit": "Düzenle",
+ "deleteTrigger": "Tetiği Sil",
+ "lastTriggered": "En son tetikleme"
+ },
+ "type": {
+ "thumbnail": "Küçük Resim",
+ "description": "Açıklama"
+ },
+ "actions": {
+ "alert": "Alarm Olarak İşaretle",
+ "notification": "Bildirim Gönder",
+ "sub_label": "Alt Etiket Ekle",
+ "attribute": "Özellik Ekle"
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Tetik {{name}} başarıyla oluşturuldu.",
+ "updateTrigger": "Tetik {{name}} başarıyla güncellendi.",
+ "deleteTrigger": "Tetik {{name}} başarıyla silindi."
+ },
+ "error": {
+ "createTriggerFailed": "Tetik oluşturulamadı: {{errorMessage}}",
+ "updateTriggerFailed": "Tetik güncellenemedi: {{errorMessage}}",
+ "deleteTriggerFailed": "Tetik silinemedi: {{errorMessage}}"
+ }
+ },
+ "semanticSearch": {
+ "title": "Anlamsal Arama devre dışı bırakıldı",
+ "desc": "Tetikleyicileri kullanmak için Anlamsal Arama'nın etkinleştirilmesi gerekir."
+ },
+ "wizard": {
+ "title": "Tetikleyici Oluştur",
+ "step1": {
+ "description": "Tetikleyiciniz için temel ayarları yapılandırın."
+ },
+ "step2": {
+ "description": "Bu eylemi tetikleyecek içeriği ayarlayın."
+ },
+ "step3": {
+ "description": "Bu tetikleyici için eşik değerini ve eylemleri yapılandırın."
+ },
+ "steps": {
+ "nameAndType": "İsim ve Tür",
+ "configureData": "Verileri Yapılandır",
+ "thresholdAndActions": "Eşik ve Eylemler"
+ }
+ }
+ },
+ "cameraWizard": {
+ "title": "Kamera Ekle",
+ "description": "Aşağıdaki adımları izleyerek Frigate kurulumunuza yeni bir kamera ekleyin.",
+ "steps": {
+ "nameAndConnection": "İsim & Bağlantı",
+ "probeOrSnapshot": "Probe veya Anlık Görüntü",
+ "streamConfiguration": "Akış Yapılandırması",
+ "validationAndTesting": "Doğrulama ve Test"
+ },
+ "save": {
+ "success": "Yeni kamera {{cameraName}} başarıyla kaydedildi.",
+ "failure": "{{cameraName}} kaydedilirken hata oluştu."
+ },
+ "testResultLabels": {
+ "resolution": "Çözünürlük",
+ "video": "Video",
+ "audio": "Ses",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Lütfen geçerli bir akış URL'si sağlayın",
+ "testFailed": "Akış testi başarısız oldu: {{error}}"
+ },
+ "step1": {
+ "description": "Kamera bilgilerinizi girin ve kamerayı taramayı (probe) ya da markayı manuel olarak seçmeyi tercih edin.",
+ "cameraName": "Kamera İsmi",
+ "cameraNamePlaceholder": "örn. onkapi, veya Arka Bahçe Genel Görünümü",
+ "host": "Ana makine adı veya IP Adresi",
+ "port": "Port",
+ "username": "Kullanıcı adı",
+ "usernamePlaceholder": "İsteğe bağlı",
+ "password": "Parola",
+ "passwordPlaceholder": "İsteğe bağlı",
+ "selectTransport": "İletişim protokolünü seçin",
+ "cameraBrand": "Kamera Markası",
+ "selectBrand": "URL şablonu için kamera markasını seçin",
+ "customUrl": "Özel Akış URL’si",
+ "brandInformation": "Marka Bilgileri",
+ "brandUrlFormat": "RTSP URL formatı şu şekilde olan kameralar için: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://kullanıcıadı:parola@host:port/path",
+ "connectionSettings": "Bağlantı Ayarları",
+ "detectionMethod": "Akış Algılama Yöntemi",
+ "onvifPort": "ONVIF Portu",
+ "probeMode": "Kamerayı tara",
+ "manualMode": "Manuel seçim",
+ "detectionMethodDescription": "Kamera akış URL’lerini bulmak için kamerayı ONVIF ile tarayın (destekleniyorsa) veya ön tanımlı URL’leri kullanmak için kamera markasını manuel olarak seçin. Özel bir RTSP URL’si girmek için manuel yöntemi seçin ve “Diğer”i işaretleyin.",
+ "onvifPortDescription": "ONVIF'i destekleyen kameralarda bu genellikle 80 veya 8080'dir.",
+ "useDigestAuth": "Digest kimlik doğrulamasını kullan",
+ "errors": {
+ "nameRequired": "Kamera ismi gereklidir",
+ "nameLength": "Kamera ismi en fazla 64 karakter olmalıdır",
+ "invalidCharacters": "Kamera ismi geçersiz karakterler içeriyor",
+ "nameExists": "Kamera ismi zaten mevcut",
+ "customUrlRtspRequired": "Özel URL'ler \"rtsp://\" ile başlamalıdır. RTSP olmayan kamera akışları için manuel yapılandırma gereklidir.",
+ "brandOrCustomUrlRequired": "Bir kamera markası seçip host/IP adresi girin ya da özel bir URL kullanmak için ‘Diğer’ seçeneğini tercih edin"
+ },
+ "useDigestAuthDescription": "ONVIF için HTTP digest kimlik doğrulamasını kullanın. Bazı kameralar, standart yönetici kullanıcısı yerine özel bir ONVIF kullanıcı adı/parola kullanılmasını gerektirebilir."
+ },
+ "step2": {
+ "description": "Mevcut akışları bulmak için kamerayı tarayın veya seçtiğiniz algılama yöntemine göre manuel ayarları yapılandırın.",
+ "testSuccess": "Bağlantı testi başarılı!",
+ "testFailed": "Bağlantı testi başarısız oldu. Lütfen bilgileri kontrol edip tekrar deneyin.",
+ "testFailedTitle": "Test Başarısız",
+ "streamDetails": "Akış Ayrıntıları",
+ "probing": "Kamera taranıyor...",
+ "retry": "Yeniden dene",
+ "testing": {
+ "probingMetadata": "Kamera meta verileri inceleniyor...",
+ "fetchingSnapshot": "Kamera anlık görüntüsü alınıyor..."
+ },
+ "probeFailed": "Kamerayı tarama başarısız oldu: {{error}}",
+ "probingDevice": "Cihaz taranıyor…",
+ "probeSuccessful": "Tarama başarılı",
+ "probeError": "Tarama hatası",
+ "probeNoSuccess": "Tarama başarısız",
+ "deviceInfo": "Cihaz Bilgileri",
+ "manufacturer": "Üretici",
+ "model": "Modeli",
+ "firmware": "Donanım yazılımı",
+ "profiles": "Profiller",
+ "ptzSupport": "PTZ Desteği",
+ "autotrackingSupport": "Otomatik Takip Desteği",
+ "presets": "Ön ayarlar",
+ "rtspCandidates": "RTSP Yayınları",
+ "rtspCandidatesDescription": "Kamera taramasından aşağıdaki RTSP URL'leri bulundu. Akış meta verilerini görüntülemek için bağlantıyı test edin.",
+ "noRtspCandidates": "Kameradan RTSP URL'si bulunamadı. Kimlik bilgileriniz yanlış olabilir veya kamera ONVIF'i veya RTSP URL'lerini almak için kullanılan yöntemi desteklemiyor olabilir. Geri dönün ve RTSP URL'sini manuel olarak girin.",
+ "candidateStreamTitle": "Yayın {{number}}",
+ "useCandidate": "Kullan",
+ "uriCopy": "Kopyala",
+ "uriCopied": "URI panoya kopyalandı",
+ "testConnection": "Bağlantıyı Test Et",
+ "toggleUriView": "Tam URI görünümünü değiştirmek için tıklayın",
+ "connected": "Bağlandı",
+ "notConnected": "Bağlı Değil",
+ "errors": {
+ "hostRequired": "Host/IP adresi gereklidir"
+ }
+ },
+ "step3": {
+ "description": "Akış rollerini yapılandırın ve kameranız için ek akışlar ekleyin.",
+ "streamsTitle": "Kamera Akışları",
+ "addStream": "Akış Ekle",
+ "addAnotherStream": "Başka Bir Akış Ekle",
+ "streamTitle": "Akış {{number}}",
+ "streamUrl": "Akış URL'si",
+ "streamUrlPlaceholder": "rtsp://kullanıcıadı:parola@host:port/path",
+ "selectStream": "Bir akış seçin",
+ "searchCandidates": "Yayınları arayın...",
+ "noStreamFound": "Akış bulunamadı",
+ "url": "URL",
+ "resolution": "Çözünürlük",
+ "selectResolution": "Çözünürlüğü seçin",
+ "quality": "Kalite",
+ "selectQuality": "Kaliteyi seçin",
+ "roles": "Roller",
+ "roleLabels": {
+ "detect": "Nesne Algılama",
+ "record": "Kayıt",
+ "audio": "Ses"
+ },
+ "testStream": "Bağlantıyı Test Et",
+ "testSuccess": "Yayın testi başarılı!",
+ "testFailed": "Yayın testi başarısız oldu",
+ "testFailedTitle": "Test Başarısız",
+ "connected": "Bağlı",
+ "notConnected": "Bağlı Değil",
+ "featuresTitle": "Özellikler",
+ "go2rtc": "Kameraya olan bağlantıları azaltın",
+ "detectRoleWarning": "Devam edebilmek için en az bir akışın algılama (detect) rolüne sahip olması gerekir.",
+ "rolesPopover": {
+ "title": "Akış Rolleri",
+ "detect": "Nesne algılama için ana besleme.",
+ "record": "Yapılandırma ayarlarına göre video akışının bölümlerini kaydeder.",
+ "audio": "Ses tabanlı algılama için besleme."
+ },
+ "featuresPopover": {
+ "title": "Yayın Özellikleri",
+ "description": "Kameranıza olan bağlantıları azaltmak için go2rtc yeniden akışını kullanın."
+ }
+ },
+ "step4": {
+ "disconnectStream": "Bağlantıyı kes",
+ "estimatedBandwidth": "Tahmini Bant Genişliği",
+ "roles": "Roller",
+ "ffmpegModule": "Yayın uyumluluk modunu kullan",
+ "ffmpegModuleDescription": "Yayın birkaç denemeden sonra yüklenmezse, bunu etkinleştirmeyi deneyin. Etkinleştirildiğinde, Frigate go2rtc ile ffmpeg modülünü kullanacaktır. Bu, bazı kamera yayınları ile daha iyi uyumluluk sağlayabilir.",
+ "none": "Hiçbiri",
+ "error": "Hata",
+ "description": "Yeni kameranızı kaydetmeden önce son doğrulama ve analiz. Kaydetmeden önce her akışı bağlayın.",
+ "validationTitle": "Akış Doğrulaması",
+ "connectAllStreams": "Tüm Akışlara Bağlan",
+ "reconnectionSuccess": "Yeniden bağlantı başarılı.",
+ "reconnectionPartial": "Bazı Akışlara yeniden bağlanılamadı.",
+ "streamUnavailable": "Akış önizlemesi kullanılamıyor",
+ "reload": "Yeniden yükle",
+ "connecting": "Bağlanıyor...",
+ "streamTitle": "Akış {{number}}",
+ "valid": "Geçerli",
+ "failed": "Başarısız",
+ "notTested": "Test edilmedi",
+ "connectStream": "Bağlan",
+ "connectingStream": "Bağlanıyor",
+ "streamValidated": "{{number}} nolu akış başarıyla doğrulandı",
+ "streamValidationFailed": "{{number}} nolu akış doğrulanamadı",
+ "saveAndApply": "Yeni Kamerayı Kaydet",
+ "saveError": "Geçersiz yapılandırma. Lütfen ayarlarınızı kontrol edin.",
+ "issues": {
+ "title": "Akış Doğrulaması",
+ "videoCodecGood": "Video kodeği {{codec}}.",
+ "audioCodecGood": "Ses kodeği {{codec}}.",
+ "resolutionHigh": "{{resolution}} çözünürlüğü kaynak kullanımının artmasına neden olabilir.",
+ "resolutionLow": "{{resolution}} çözünürlüğü, küçük nesnelerin güvenilir bir şekilde algılanması için çok düşük olabilir.",
+ "noAudioWarning": "Bu yayın için ses algılanmadı, kayıtlarda ses bulunmayacak.",
+ "audioCodecRecordError": "Kayıtlarda sesi desteklemek için AAC ses kodeği gereklidir.",
+ "audioCodecRequired": "Ses algılamayı desteklemek için bir ses akışı gereklidir.",
+ "restreamingWarning": "Kayıt akışı için kameraya olan bağlantıları azaltmak CPU kullanımını bir miktar artırabilir.",
+ "brands": {
+ "reolink-rtsp": "Reolink RTSP önerilmez. Kameranın ayarlarında HTTP'yi etkinleştirin ve sihirbazı baştan başlatın.",
+ "reolink-http": "Reolink HTTP akışları daha iyi uyumluluk için FFmpeg kullanmalıdır. Bu akış için 'Akış uyumluluk modunu kullan' seçeneğini etkinleştirin."
+ },
+ "dahua": {
+ "substreamWarning": "Alt akış 1 düşük çözünürlüğe kilitlenmiştir. Birçok Dahua / Amcrest / EmpireTech kamera, kamera ayarlarında etkinleştirilmesi gereken ek alt akışları destekler. Mevcutsa, bu akışları kontrol edip kullanmanız önerilir."
+ },
+ "hikvision": {
+ "substreamWarning": "Alt akış 1 düşük çözünürlüğe kilitlendi. Birçok Hikvision kamera, kamera ayarlarında etkinleştirilmesi gereken ek alt akışları destekler. Mevcutsa, bu akışları kontrol edip kullanmanız önerilir."
+ }
+ }
+ }
+ },
+ "cameraManagement": {
+ "title": "Kameraları Yönet",
+ "addCamera": "Yeni Kamera Ekle",
+ "editCamera": "Kamerayı Düzenle:",
+ "selectCamera": "Bir Kamera Seçin",
+ "backToSettings": "Kamera Ayarlarına Dön",
+ "streams": {
+ "title": "Kameraları Etkinleştir / Devre Dışı Bırak",
+ "desc": "Frigate yeniden başlatılana kadar bir kamerayı geçici olarak devre dışı bırakın. Bir kamerayı devre dışı bırakmak, Frigate'in bu kameranın akışlarını işlemesini tamamen durdurur. Algılama, kayıt ve hata ayıklama kullanılamaz.
Not: Bu, go2rtc yeniden akışlarını devre dışı bırakmaz."
+ },
+ "cameraConfig": {
+ "add": "Kamera Ekle",
+ "edit": "Kamerayı Düzenle",
+ "description": "Yayınlar ve roller dahil olmak üzere kamera ayarlarını yapılandırın.",
+ "name": "Kamera İsmi",
+ "nameRequired": "Kamera ismi gereklidir",
+ "nameLength": "Kamera ismi 64 karakterden az olmalıdır.",
+ "namePlaceholder": "örneğin, ön_kapı veya Arka Bahçe Genel Bakışı",
+ "enabled": "Etkin",
+ "ffmpeg": {
+ "inputs": "Giriş Akışları",
+ "path": "Akış Yolu",
+ "pathRequired": "Akış yolu gereklidir",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Roller",
+ "rolesRequired": "En az bir rol gereklidir",
+ "rolesUnique": "Her rol (ses, algılama, kayıt) yalnızca bir akışa atanabilir",
+ "addInput": "Akış Ekle",
+ "removeInput": "Akış Kaldır",
+ "inputsRequired": "En az bir akış gereklidir"
+ },
+ "go2rtcStreams": "go2rtc Akışları",
+ "streamUrls": "Akış URL'leri",
+ "addUrl": "URL ekle",
+ "addGo2rtcStream": "go2rtc Akışı Ekle",
+ "toast": {
+ "success": "Kamera {{cameraName}} başarıyla kaydedildi"
+ }
+ }
+ },
+ "cameraReview": {
+ "title": "Kamera İnceleme Ayarları",
+ "object_descriptions": {
+ "title": "Üretken Yapay Zeka Nesne Açıklamaları",
+ "desc": "Frigate yeniden başlatılana kadar bu kamera için Üretken Yapay Zeka nesne açıklamalarını geçici olarak etkinleştirin/devre dışı bırakın. Devre dışı bırakıldığında, bu kameradaki izlenen nesneler için yapay zeka tarafından oluşturulan açıklamalar istenmeyecektir."
+ },
+ "review_descriptions": {
+ "title": "Üretken Yapay Zeka İnceleme Açıklamaları",
+ "desc": "Bu kamera için yapay zekadan incele öğelerini açıklama taleplerini geçici olarak etkinleştirin/devre dışı bırakın. Devre dışı bırakıldığında, bu kameradaki inceleme öğeleri için yapay zekadan açıklama istenmeyecektir."
+ },
+ "review": {
+ "title": "İncele",
+ "desc": "Frigate yeniden başlatılana kadar bu kamera için uyarıları ve algılamaları geçici olarak etkinleştirin/devre dışı bırakın. Devre dışı bırakıldığında, yeni inceleme öğeleri oluşturulmaz. ",
+ "alerts": "Uyarılar ",
+ "detections": "Tespitler "
+ },
+ "reviewClassification": {
+ "title": "Sınıflandırmayı İncele",
+ "desc": "Frigate, inceleme öğelerini Uyarılar ve Algılamalar olarak kategorilere ayırır. Varsayılan olarak, tüm kişi ve araba nesneleri Uyarı olarak kabul edilir. İnceleme öğelerinizin kategorilendirmesini, bunlar için gerekli bölgeleri yapılandırarak iyileştirebilirsiniz.",
+ "noDefinedZones": "Bu kamera için herhangi bir bölge tanımlanmamıştır.",
+ "objectAlertsTips": "{{cameraName}} üzerindeki tüm {{alertsLabels}} nesneleri Uyarı olarak gösterilecektir.",
+ "zoneObjectAlertsTips": "{{cameraName}} üzerinde, {{zone}} bölgesinde tespit edilen tüm {{alertsLabels}} nesneleri Uyarı olarak gösterilecektir.",
+ "objectDetectionsTips": "{{cameraName}} üzerinde kategorize edilmemiş tüm {{detectionsLabels}} nesneleri, bölgeden bağımsız olarak Tespit olarak gösterilecektir.",
+ "zoneObjectDetectionsTips": {
+ "text": "{{cameraName}} üzerindeki {{zone}} bölgesinde kategorize edilmemiş tüm {{detectionsLabels}} nesneleri, Tespit olarak gösterilecektir.",
+ "notSelectDetections": "{{cameraName}} üzerinde {{zone}} bölgesinde tespit edilen ve Uyarı olarak kategorize edilmemiş tüm {{detectionsLabels}} nesneleri, bölgeden bağımsız olarak Tespitler olarak gösterilecektir.",
+ "regardlessOfZoneObjectDetectionsTips": "{{cameraName}} üzerinde kategorize edilmemiş tüm {{detectionsLabels}} nesneleri, bulundukları bölgeden bağımsız olarak Tespit olarak gösterilecektir."
+ },
+ "unsavedChanges": "{{camera}} için Kaydedilmemiş İnceleme Sınıflandırması ayarları",
+ "selectAlertsZones": "Uyarılar için bölgeleri seçin",
+ "selectDetectionsZones": "Tespitler için bölgeleri seçin",
+ "limitDetections": "Tespitleri belirli bölgelerle sınırlayın",
+ "toast": {
+ "success": "Sınıflandırma yapılandırması kaydedildi. Değişiklikleri uygulamak için Frigate'i yeniden başlatın."
+ }
+ }
+ },
+ "roles": {
+ "management": {
+ "title": "İzleyici Rol Yönetimi",
+ "desc": "Bu Frigate örneği için özel görüntüleyici rollerini ve kamera erişim izinlerini yönetin."
+ },
+ "addRole": "Rol Ekle",
+ "table": {
+ "role": "Rol",
+ "cameras": "Kameralar",
+ "actions": "Eylemler",
+ "noRoles": "Özel rol bulunamadı.",
+ "editCameras": "Kameraları Düzenle",
+ "deleteRole": "Rolü Sil"
+ },
+ "toast": {
+ "success": {
+ "createRole": "{{role}} rolü başarıyla oluşturuldu",
+ "updateCameras": "{{role}} rolü için kameralar güncellendi",
+ "deleteRole": "{{role}} rolü başarıyla silindi",
+ "userRolesUpdated_one": "Bu role atanan {{count}} kullanıcı, tüm kameralara erişimi olan 'görüntüleyici' olarak güncellendi.",
+ "userRolesUpdated_other": "Bu role atanan {{count}} kullanıcı, tüm kameralara erişimi olan 'görüntüleyici' olarak güncellendi."
+ },
+ "error": {
+ "createRoleFailed": "Rol oluşturulamadı: {{errorMessage}}",
+ "updateCamerasFailed": "Kameralar güncellenemedi: {{errorMessage}}",
+ "deleteRoleFailed": "Rol silinemedi: {{errorMessage}}",
+ "userUpdateFailed": "Kullanıcı rolleri güncellenemedi: {{errorMessage}}"
+ }
+ },
+ "dialog": {
+ "createRole": {
+ "title": "Yeni Rol Oluştur",
+ "desc": "Yeni bir rol ekleyin ve kamera erişim izinlerini belirtin."
+ },
+ "editCameras": {
+ "title": "Rol Kameralarını Düzenle",
+ "desc": "{{role}} rolü için kamera erişimini güncelleyin."
+ },
+ "deleteRole": {
+ "title": "Rolü Sil",
+ "desc": "Bu işlem geri alınamaz. Bu işlem, rolü kalıcı olarak siler ve bu role sahip tüm kullanıcılara 'izleyici' rolü atar; bu da izleyiciye tüm kameralara erişim sağlar.",
+ "warn": "{{role}} rolünü silmek istediğinizden emin misiniz?",
+ "deleting": "Siliniyor..."
+ },
+ "form": {
+ "role": {
+ "title": "Rol İsmi",
+ "placeholder": "Rol ismini girin",
+ "desc": "Sadece harf, rakam, nokta ve alt çizgi kullanılabilir.",
+ "roleIsRequired": "Rol ismi gereklidir",
+ "roleOnlyInclude": "Rol ismi yalnızca harf, sayı veya alt çizgi (_) içerebilir",
+ "roleExists": "Bu isimde bir rol zaten mevcut."
+ },
+ "cameras": {
+ "title": "Kameralar",
+ "desc": "Bu rolün erişebileceği kameraları seçin. En az bir kamera gereklidir.",
+ "required": "En az bir kamera seçilmelidir."
+ }
+ }
+ }
}
}
diff --git a/web/public/locales/tr/views/system.json b/web/public/locales/tr/views/system.json
index 9124e3e08..d38811843 100644
--- a/web/public/locales/tr/views/system.json
+++ b/web/public/locales/tr/views/system.json
@@ -43,19 +43,32 @@
"gpuEncoder": "GPU Kodlayıcı",
"title": "Donanım Bilgisi",
"npuUsage": "NPU Kullanımı",
- "npuMemory": "NPU Bellek Kullanımı"
+ "npuMemory": "NPU Bellek Kullanımı",
+ "intelGpuWarning": {
+ "title": "Intel GPU İstatistik Uyarısı",
+ "message": "GPU istatistikleri kullanılamıyor",
+ "description": "Bu durum, donanımsal hızlandırma ve nesne tespiti (i)GPU üzerinde sorunsuz çalışıyor olsa bile, Intel’in GPU istatistik raporlama aracındaki (intel_gpu_top) bilinen bir hatadan ötürü GPU kullanımının %0 olarak bildirilmesinden kaynaklanmakta olup, Frigate hatası değildir. Sorunu geçici olarak düzeltmek ve (i)GPU’nun doğru çalıştığını doğrulamak için ana makineyi yeniden başlatabilirsiniz. Bu durum performansı etkilememektedir."
+ }
},
"otherProcesses": {
"title": "Diğer İşlemler",
"processCpuUsage": "İşlem CPU Kullanımı",
- "processMemoryUsage": "İşlem Bellek Kullanımı"
+ "processMemoryUsage": "İşlem Bellek Kullanımı",
+ "series": {
+ "go2rtc": "go2rtc",
+ "recording": "kayıt",
+ "embeddings": "gömüler",
+ "audio_detector": "ses detektörü",
+ "review_segment": "inceleme bölümü"
+ }
},
"detector": {
"title": "Algılayıcılar",
"inferenceSpeed": "Algılayıcı Çıkarım Hızı",
"memoryUsage": "Algılayıcı Bellek Kullanımı",
"cpuUsage": "Algılayıcı İşlemci Kullanımı",
- "temperature": "Algılayıcı Sıcaklığı"
+ "temperature": "Algılayıcı Sıcaklığı",
+ "cpuUsageInformation": "Tespit modellerine giriş ve çıkış verilerini hazırlarken kullanılan işlemci yoğunluğu. Bu değer, grafik işlemci veya benzeri bir hızlandırıcı kullanılsa bile çıkarım yükünü ölçmek için kullanılmamalıdır."
},
"title": "Genel"
},
@@ -78,6 +91,10 @@
"storageUsed": "Depolama",
"bandwidth": "Saatlik Veri Kullanımı",
"unusedStorageInformation": "Kullanılmayan Depolama Bilgisi"
+ },
+ "shm": {
+ "warning": "Şu anki {{total}}MB'lik SHM boyutu yetersiz. Bu boyutu en az {{min_shm}}MB'a çıkartın.",
+ "title": "Ayrılan SHM (paylaşımlı bellek)"
}
},
"cameras": {
@@ -134,7 +151,8 @@
"healthy": "Sistem sağlıklı",
"detectIsVerySlow": "{{detect}} çok yavaş çalışıyor ({{speed}} ms)",
"cameraIsOffline": "{{camera}} çevrimdışı",
- "detectIsSlow": "{{detect}} yavaş çalışıyor ({{speed}} ms)"
+ "detectIsSlow": "{{detect}} yavaş çalışıyor ({{speed}} ms)",
+ "shmTooLow": "Ayrılan /dev/shm belleği (şu anda {{total}} MB), en az {{min}} MB'a çıkartılmalıdır."
},
"enrichments": {
"embeddings": {
@@ -148,10 +166,20 @@
"plate_recognition": "Plaka Tanıma",
"face_recognition_speed": "Yüz Tanıma Hızı",
"yolov9_plate_detection_speed": "YOLOv9 Plaka Tanıma Hızı",
- "yolov9_plate_detection": "YOLOv9 Plaka Tanıma"
+ "yolov9_plate_detection": "YOLOv9 Plaka Tanıma",
+ "review_description": "İnceleme Açıklaması",
+ "review_description_speed": "İnceleme Açıklama Hızı",
+ "review_description_events_per_second": "İnceleme Açıklaması",
+ "object_description": "Nesne Açıklaması",
+ "object_description_speed": "Nesne Açıklama Hızı",
+ "object_description_events_per_second": "Nesne Açıklaması",
+ "classification": "{{name}} Sınıflandırması",
+ "classification_speed": "{{name}} Sınıflandırma Hızı",
+ "classification_events_per_second": "{{name}} Saniyede Sınıflandırma Olayları"
},
"infPerSecond": "Saniye Başına Çıkarım",
- "title": "Zenginleştirmeler"
+ "title": "Zenginleştirmeler",
+ "averageInf": "Ortalama Çıkarım Süresi"
},
"logs": {
"download": {
diff --git a/web/public/locales/uk/audio.json b/web/public/locales/uk/audio.json
index e5b27820a..773d5e3a7 100644
--- a/web/public/locales/uk/audio.json
+++ b/web/public/locales/uk/audio.json
@@ -425,5 +425,79 @@
"whistling": "Свист",
"snoring": "Хропіння",
"pant": "Задихатися",
- "sneeze": "Чхати"
+ "sneeze": "Чхати",
+ "sodeling": "Соделінг",
+ "chird": "Дитина",
+ "change_ringing": "Змінити дзвінок",
+ "shofar": "Шофар",
+ "liquid": "Рідина",
+ "splash": "Сплеск",
+ "slosh": "Сльоз",
+ "squish": "Хлюпати",
+ "drip": "Крапельне",
+ "pour": "Для",
+ "trickle": "Струмінь",
+ "gush": "Гуш",
+ "fill": "Заповнити",
+ "spray": "Спрей",
+ "pump": "Насос",
+ "stir": "Перемішати",
+ "boiling": "Кипіння",
+ "sonar": "Сонар",
+ "arrow": "Стрілка",
+ "whoosh": "Свисти",
+ "thump": "Тупіт",
+ "thunk": "Тюнк",
+ "electronic_tuner": "Електронний тюнер",
+ "effects_unit": "Блок ефектів",
+ "chorus_effect": "Ефект хорусу",
+ "basketball_bounce": "Відскок баскетбольного м'яча",
+ "bang": "Вибухи",
+ "slap": "Ляпас",
+ "whack": "Вдарити",
+ "smash": "Розгром",
+ "breaking": "Розбиттям",
+ "bouncing": "Підстрибування",
+ "whip": "Батіг",
+ "flap": "Клаптик",
+ "scratch": "Подряпина",
+ "scrape": "Скрейп",
+ "rub": "Розтирання",
+ "roll": "Рулон",
+ "crushing": "Дроблення",
+ "crumpling": "Зминання",
+ "tearing": "Розривання",
+ "beep": "Звуковий сигнал",
+ "ping": "Пінг",
+ "ding": "Дін",
+ "clang": "Брязкіт",
+ "squeal": "Вереск",
+ "creak": "Скрипи",
+ "rustle": "Шелест",
+ "whir": "Гудінням",
+ "clatter": "Брязкіти",
+ "sizzle": "Шипінням",
+ "clicking": "Клацання",
+ "clickety_clack": "Клацання-Клак",
+ "rumble": "Гуркіті",
+ "plop": "Плюх",
+ "hum": "Гум",
+ "zing": "Зінг",
+ "boing": "Боїнг",
+ "crunch": "Хрускіт",
+ "sine_wave": "Синусоїда",
+ "harmonic": "Гармоніка",
+ "chirp_tone": "Чирп-тон",
+ "pulse": "Пульс",
+ "inside": "Всередині",
+ "outside": "Зовні",
+ "reverberation": "Реверберація",
+ "echo": "Відлуння",
+ "noise": "Шум",
+ "mains_hum": "Гуміння рук",
+ "distortion": "Спотворення",
+ "sidetone": "Побічний тон",
+ "cacophony": "Какофонія",
+ "throbbing": "Пульсуючий",
+ "vibration": "Вібрація"
}
diff --git a/web/public/locales/uk/common.json b/web/public/locales/uk/common.json
index 029364971..39dff176f 100644
--- a/web/public/locales/uk/common.json
+++ b/web/public/locales/uk/common.json
@@ -78,7 +78,11 @@
"formattedTimestampMonthDayYear": {
"24hour": "MMM d, yyyy",
"12hour": "MMM d, yyyy"
- }
+ },
+ "inProgress": "У процесі",
+ "invalidStartTime": "Недійсний час початку",
+ "invalidEndTime": "Недійсний час завершення",
+ "never": "Ніколи"
},
"button": {
"exitFullscreen": "Вийти з повноекранного режиму",
@@ -115,7 +119,8 @@
"export": "Експортувати",
"deleteNow": "Видалити негайно",
"next": "Наступне",
- "unsuspended": "Відновити дію"
+ "unsuspended": "Відновити дію",
+ "continue": "Продовжити"
},
"menu": {
"language": {
@@ -152,7 +157,15 @@
"en": "Англійська",
"yue": "粵語 (Кантонська)",
"th": "ไทย (Тайська)",
- "ca": "Català (Каталанська)"
+ "ca": "Català (Каталанська)",
+ "ptBR": "Português brasileiro (Бразильська португальська)",
+ "sr": "Српски (Сербська)",
+ "sl": "Slovenščina (Словенська)",
+ "lt": "Lietuvių (Литовська)",
+ "bg": "Български (Болгарська)",
+ "gl": "Galego (Галісійська)",
+ "id": "Bahasa Indonesia (Індонезійська)",
+ "ur": "اردو (Урду)"
},
"system": "Система",
"systemMetrics": "Системна метріка",
@@ -178,7 +191,7 @@
},
"restart": "Перезапустити Frigate",
"live": {
- "title": "Живи",
+ "title": "Пряма трансляція",
"allCameras": "Всi камери",
"cameras": {
"title": "Камери",
@@ -208,8 +221,9 @@
"label": "Використовуйте налаштування системи для світлого або темного режиму"
}
},
- "appearance": "Поява",
- "withSystem": "Система"
+ "appearance": "Зовнішність",
+ "withSystem": "Система",
+ "classification": "Класифікація"
},
"unit": {
"speed": {
@@ -219,10 +233,24 @@
"length": {
"feet": "ноги",
"meters": "метрів"
+ },
+ "data": {
+ "kbps": "кБ/с",
+ "mbps": "МБ/с",
+ "gbps": "ГБ/с",
+ "kbph": "кБ/годину",
+ "mbph": "МБ/годину",
+ "gbph": "ГБ/годину"
}
},
"label": {
- "back": "Повернутись"
+ "back": "Повернутись",
+ "hide": "Приховати {{item}}",
+ "show": "Показати {{item}}",
+ "ID": "ID",
+ "none": "Жоден",
+ "all": "Усі",
+ "other": "Інше"
},
"toast": {
"save": {
@@ -262,5 +290,18 @@
"desc": "Сторінка не знайдена",
"title": "404"
},
- "selectItem": "Вибрати {{item}}"
+ "selectItem": "Вибрати {{item}}",
+ "readTheDocumentation": "Прочитати документацію",
+ "information": {
+ "pixels": "{{area}}пикс"
+ },
+ "list": {
+ "two": "{{0}} і {{1}}",
+ "many": "{{items}}, і {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Необов'язково",
+ "internalID": "Внутрішній ідентифікатор, який Frigate використовує в конфігурації та базі даних"
+ }
}
diff --git a/web/public/locales/uk/components/auth.json b/web/public/locales/uk/components/auth.json
index 07eaca4e3..4c9f7e282 100644
--- a/web/public/locales/uk/components/auth.json
+++ b/web/public/locales/uk/components/auth.json
@@ -10,6 +10,7 @@
},
"user": "Iм'я користувача",
"password": "Пароль",
- "login": "Логiн"
+ "login": "Логiн",
+ "firstTimeLogin": "Намагаєтеся вперше увійти? Облікові дані надруковані в журналах Frigate."
}
}
diff --git a/web/public/locales/uk/components/camera.json b/web/public/locales/uk/components/camera.json
index 76886a7b8..0836510e1 100644
--- a/web/public/locales/uk/components/camera.json
+++ b/web/public/locales/uk/components/camera.json
@@ -50,7 +50,8 @@
},
"stream": "Потік",
"placeholder": "Виберіть потік"
- }
+ },
+ "birdseye": "Бердсай"
},
"edit": "Редагувати групу камер",
"delete": {
diff --git a/web/public/locales/uk/components/dialog.json b/web/public/locales/uk/components/dialog.json
index 43cb9bd9b..7ede7901b 100644
--- a/web/public/locales/uk/components/dialog.json
+++ b/web/public/locales/uk/components/dialog.json
@@ -57,7 +57,8 @@
"endTimeMustAfterStartTime": "Час закінчення повинен бути після часу початку",
"noVaildTimeSelected": "Не вибрано допустимий діапазон часу"
},
- "success": "Експорт успішно запущено. Файл доступний у теці /exports."
+ "success": "Експорт успішно розпочато. Перегляньте файл на сторінці експорту.",
+ "view": "Переглянути"
},
"fromTimeline": {
"saveExport": "Зберегти експорт",
@@ -89,7 +90,8 @@
"button": {
"export": "Експорт",
"markAsReviewed": "Позначити як переглянуте",
- "deleteNow": "Вилучити зараз"
+ "deleteNow": "Вилучити зараз",
+ "markAsUnreviewed": "Позначити як непереглянуте"
},
"confirmDelete": {
"title": "Підтвердити вилучення",
@@ -110,5 +112,13 @@
"content": "Цю сторінку буде перезавантажено за {{countdown}} секунд.",
"button": "Примусово перезавантажити"
}
+ },
+ "imagePicker": {
+ "selectImage": "Вибір мініатюри відстежуваного об'єкта",
+ "search": {
+ "placeholder": "Пошук за міткою або підміткою..."
+ },
+ "noImages": "Для цієї камери не знайдено мініатюр",
+ "unknownLabel": "Збережене зображення тригера"
}
}
diff --git a/web/public/locales/uk/components/filter.json b/web/public/locales/uk/components/filter.json
index 95c01f349..a99867c0c 100644
--- a/web/public/locales/uk/components/filter.json
+++ b/web/public/locales/uk/components/filter.json
@@ -97,7 +97,7 @@
"score": "Рахунок",
"estimatedSpeed": "Розрахункова швидкість ({{unit}})",
"review": {
- "showReviewed": "Показати переглянув"
+ "showReviewed": "Показувати переглянуті"
},
"motion": {
"showMotionOnly": "Показати тiльки рух"
@@ -121,6 +121,20 @@
"loading": "Завантаження визнаних номерів…",
"placeholder": "Введіть для пошуку номерні знаки…",
"noLicensePlatesFound": "Номерних знаків не знайдено.",
- "selectPlatesFromList": "Виберіть одну або кілька пластин зі списку."
+ "selectPlatesFromList": "Виберіть одну або кілька пластин зі списку.",
+ "selectAll": "Вибрати все",
+ "clearAll": "Очистити все"
+ },
+ "classes": {
+ "label": "Заняття",
+ "all": {
+ "title": "Усі класи"
+ },
+ "count_one": "Клас {{count}}",
+ "count_other": "{{count}} Класи"
+ },
+ "attributes": {
+ "label": "Атрибути класифікації",
+ "all": "Усі атрибути"
}
}
diff --git a/web/public/locales/uk/views/classificationModel.json b/web/public/locales/uk/views/classificationModel.json
new file mode 100644
index 000000000..a96997bc7
--- /dev/null
+++ b/web/public/locales/uk/views/classificationModel.json
@@ -0,0 +1,193 @@
+{
+ "documentTitle": "Моделі класифікації - Frigate",
+ "button": {
+ "deleteClassificationAttempts": "Видалити зображення класифікації",
+ "renameCategory": "Перейменувати клас",
+ "deleteCategory": "Видалити клас",
+ "deleteImages": "Видалити зображення",
+ "trainModel": "Модель поїзда",
+ "addClassification": "Додати класифікацію",
+ "deleteModels": "Видалити моделі",
+ "editModel": "Редагувати модель"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Видалений клас",
+ "deletedImage": "Видалені зображення",
+ "categorizedImage": "Зображення успішно класифіковано",
+ "trainedModel": "Успішно навчена модель.",
+ "trainingModel": "Успішно розпочато навчання моделі.",
+ "deletedModel_one": "Успішно видалено модель {{count}}",
+ "deletedModel_few": "Успішно видалено моделей {{count}}",
+ "deletedModel_many": "Успішно видалено моделі {{count}}",
+ "updatedModel": "Конфігурацію моделі успішно оновлено",
+ "renamedCategory": "Клас успішно перейменовано на {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Не вдалося видалити: {{errorMessage}}",
+ "deleteCategoryFailed": "Не вдалося видалити клас: {{errorMessage}}",
+ "categorizeFailed": "Не вдалося класифікувати зображення: {{errorMessage}}",
+ "trainingFailed": "Навчання моделі не вдалося. Перегляньте журнали Frigate для отримання детальної інформації.",
+ "deleteModelFailed": "Не вдалося видалити модель: {{errorMessage}}",
+ "updateModelFailed": "Не вдалося оновити модель: {{errorMessage}}",
+ "renameCategoryFailed": "Не вдалося перейменувати клас: {{errorMessage}}",
+ "trainingFailedToStart": "Не вдалося розпочати навчання моделі: {{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "Видалити клас",
+ "desc": "Ви впевнені, що хочете видалити клас {{name}}? Це назавжди видалить усі пов'язані зображення та вимагатиме повторного навчання моделі.",
+ "minClassesTitle": "Не вдається видалити клас",
+ "minClassesDesc": "Модель класифікації повинна мати щонайменше 2 класи. Додайте ще один клас, перш ніж видаляти цей."
+ },
+ "deleteDatasetImages": {
+ "title": "Видалити зображення набору даних",
+ "desc_one": "Ви впевнені, що хочете видалити {{count}} зображень з {{dataset}}? Цю дію неможливо скасувати, вона вимагатиме повторного навчання моделі.",
+ "desc_few": "Ви впевнені, що хочете видалити {{count}} зображенні з {{dataset}}? Цю дію неможливо скасувати, вона вимагатиме повторного навчання моделі.",
+ "desc_many": "Ви впевнені, що хочете видалити {{count}} зображенні з {{dataset}}? Цю дію неможливо скасувати, вона вимагатиме повторного навчання моделі."
+ },
+ "deleteTrainImages": {
+ "title": "Видалити зображення поїздів",
+ "desc_one": "Ви впевнені, що хочете видалити {{count}} зображень? Цю дію не можна скасувати.",
+ "desc_few": "Ви впевнені, що хочете видалити {{count}} зображенні? Цю дію не можна скасувати.",
+ "desc_many": "Ви впевнені, що хочете видалити {{count}} зображенні? Цю дію не можна скасувати."
+ },
+ "renameCategory": {
+ "title": "Перейменувати клас",
+ "desc": "Введіть нову назву для {{name}}. Вам потрібно буде перенавчити модель, щоб зміна назви набула чинності."
+ },
+ "description": {
+ "invalidName": "Недійсне ім'я. Ім'я може містити лише літери, цифри, пробіли, апострофи, символи підкреслення та дефіси."
+ },
+ "train": {
+ "title": "Нещодавні класифікації",
+ "titleShort": "Нещодавні",
+ "aria": "Виберіть останні класифікації"
+ },
+ "categories": "Заняття",
+ "createCategory": {
+ "new": "Створити новий клас"
+ },
+ "categorizeImageAs": "Класифікувати зображення як:",
+ "categorizeImage": "Класифікувати зображення",
+ "noModels": {
+ "object": {
+ "title": "Без моделей класифікації об'єктів",
+ "description": "Створіть власну модель для класифікації виявлених об'єктів.",
+ "buttonText": "Створення об'єктної моделі"
+ },
+ "state": {
+ "title": "Без моделей класифікації штатів",
+ "description": "Створіть власну модель для моніторингу та класифікації змін стану в певних областях камери.",
+ "buttonText": "Створити модель стану"
+ }
+ },
+ "wizard": {
+ "title": "Створити нову класифікацію",
+ "steps": {
+ "nameAndDefine": "Назва та визначення",
+ "stateArea": "Площа штату",
+ "chooseExamples": "Виберіть приклади"
+ },
+ "step1": {
+ "description": "Моделі станів відстежують зміни в зонах дії фіксованих камер (наприклад, відкриття/закриття дверей). Моделі об'єктів додають класифікації до виявлених об'єктів (наприклад, відомі тварини, кур'єри тощо).",
+ "name": "Ім'я",
+ "namePlaceholder": "Введіть назву моделі...",
+ "type": "Тип",
+ "typeState": "Штат",
+ "typeObject": "Об'єкт",
+ "objectLabel": "Мітка об'єкта",
+ "objectLabelPlaceholder": "Виберіть тип об'єкта...",
+ "classificationType": "Тип класифікації",
+ "classificationTypeTip": "Дізнайтеся про типи класифікації",
+ "classificationTypeDesc": "Підмітки додають додатковий текст до мітки об’єкта (наприклад, «Особа: UPS»). Атрибути – це метадані для пошуку, що зберігаються окремо в метаданих об’єкта.",
+ "classificationSubLabel": "Підмітка",
+ "classificationAttribute": "Атрибут",
+ "classes": "Заняття",
+ "classesTip": "Дізнайтеся про заняття",
+ "classesStateDesc": "Визначте різні стани, в яких може перебувати зона вашої камери. Наприклад: «відкрито» та «закрито» для гаражних воріт.",
+ "classesObjectDesc": "Визначте різні категорії для класифікації виявлених об'єктів. Наприклад: «доставник», «мешканець», «незнайомець» для класифікації осіб.",
+ "classPlaceholder": "Введіть назву класу...",
+ "errors": {
+ "nameRequired": "Назва моделі обов'язкова",
+ "nameLength": "Назва моделі має містити не більше 64 символів",
+ "nameOnlyNumbers": "Назва моделі не може містити лише цифри",
+ "classRequired": "Потрібно хоча б 1 заняття",
+ "classesUnique": "Назви класів мають бути унікальними",
+ "stateRequiresTwoClasses": "Моделі станів вимагають щонайменше 2 класів",
+ "objectLabelRequired": "Будь ласка, виберіть мітку об'єкта",
+ "objectTypeRequired": "Будь ласка, виберіть тип класифікації",
+ "noneNotAllowed": "Клас «none» не дозволено"
+ },
+ "states": "Штати"
+ },
+ "step2": {
+ "description": "Виберіть камери та визначте область для моніторингу для кожної камери. Модель класифікуватиме стан цих областей.",
+ "cameras": "Камери",
+ "selectCamera": "Виберіть Камеру",
+ "noCameras": "Натисніть +, щоб додати камери",
+ "selectCameraPrompt": "Виберіть камеру зі списку, щоб визначити її зону спостереження"
+ },
+ "step3": {
+ "selectImagesPrompt": "Виберіть усі зображення з: {{className}}",
+ "selectImagesDescription": "Натисніть на зображення, щоб вибрати їх. Натисніть «Продовжити», коли закінчите з цим уроком.",
+ "generating": {
+ "title": "Створення зразків зображень",
+ "description": "Фрегат отримує типові зображення з ваших записів. Це може зайняти деякий час..."
+ },
+ "training": {
+ "title": "Модель навчання",
+ "description": "Ваша модель навчається у фоновому режимі. Закрийте це діалогове вікно, і ваша модель почне працювати, щойно навчання буде завершено."
+ },
+ "retryGenerate": "Генерація повторних спроб",
+ "noImages": "Немає згенерованих зразків зображень",
+ "classifying": "Класифікація та навчання...",
+ "trainingStarted": "Навчання розпочалося успішно",
+ "errors": {
+ "noCameras": "Немає налаштованих камер",
+ "noObjectLabel": "Мітку об'єкта не вибрано",
+ "generateFailed": "Не вдалося створити приклади: {{error}}",
+ "generationFailed": "Помилка генерації. Будь ласка, спробуйте ще раз.",
+ "classifyFailed": "Не вдалося класифікувати зображення: {{error}}"
+ },
+ "generateSuccess": "Зразки зображень успішно створено",
+ "allImagesRequired_one": "Будь ласка, класифікуйте всі зображення. Залишилося {{count}} зображення.",
+ "allImagesRequired_few": "Будь ласка, класифікуйте всі зображення. Залишилося зображень: {{count}}.",
+ "allImagesRequired_many": "Будь ласка, класифікуйте всі зображення. Залишилося зображень: {{count}}.",
+ "modelCreated": "Модель успішно створено. Використовуйте режим перегляду «Нещодавні класифікації», щоб додати зображення для відсутніх станів, а потім навчіть модель.",
+ "missingStatesWarning": {
+ "title": "Приклади відсутніх станів",
+ "description": "Для найкращих результатів рекомендується вибрати приклади для всіх станів. Ви можете продовжити, не вибираючи всі стани, але модель не буде навчена, доки всі стани не матимуть зображень. Після продовження скористайтеся поданням «Нещодавні класифікації», щоб класифікувати зображення для відсутніх станів, а потім навчіть модель."
+ }
+ }
+ },
+ "deleteModel": {
+ "title": "Видалити модель класифікації",
+ "single": "Ви впевнені, що хочете видалити {{name}}? Це назавжди видалить усі пов’язані дані, включаючи зображення та дані навчання. Цю дію не можна скасувати.",
+ "desc_one": "Ви впевнені, що хочете видалити {{count}} модель? Це назавжди видалить усі пов’язані дані, включаючи зображення та навчальні дані. Цю дію не можна скасувати.",
+ "desc_few": "Ви впевнені, що хочете видалити {{count}} моделей? Це назавжди видалить усі пов’язані дані, включаючи зображення та навчальні дані. Цю дію не можна скасувати.",
+ "desc_many": "Ви впевнені, що хочете видалити {{count}} моделі? Це назавжди видалить усі пов’язані дані, включаючи зображення та навчальні дані. Цю дію не можна скасувати."
+ },
+ "menu": {
+ "objects": "Об'єкти",
+ "states": "Стани"
+ },
+ "details": {
+ "scoreInfo": "Оцінка представляє середню достовірність класифікації для всіх виявлень цього об'єкта.",
+ "none": "Жоден",
+ "unknown": "Невідомо"
+ },
+ "edit": {
+ "title": "Редагувати модель класифікації",
+ "descriptionState": "Відредагуйте класи для цієї моделі класифікації штатів. Зміни вимагатимуть перенавчання моделі.",
+ "descriptionObject": "Відредагуйте тип об'єкта та тип класифікації для цієї моделі класифікації об'єктів.",
+ "stateClassesInfo": "Примітка: Зміна класів станів вимагає перенавчання моделі з використанням оновлених класів."
+ },
+ "tooltip": {
+ "trainingInProgress": "Модель зараз тренується",
+ "noNewImages": "Немає нових зображень для навчання. Спочатку класифікуйте більше зображень у наборі даних.",
+ "modelNotReady": "Модель не готова до навчання",
+ "noChanges": "З моменту останнього навчання в наборі даних не було змін."
+ },
+ "none": "Жоден"
+}
diff --git a/web/public/locales/uk/views/configEditor.json b/web/public/locales/uk/views/configEditor.json
index c9a664113..0e3ef13cb 100644
--- a/web/public/locales/uk/views/configEditor.json
+++ b/web/public/locales/uk/views/configEditor.json
@@ -12,5 +12,7 @@
"copyConfig": "Скопіювати конфігурацію",
"saveOnly": "Тільки зберегти",
"configEditor": "Налаштування редактора",
- "confirm": "Вийти без збереження?"
+ "confirm": "Вийти без збереження?",
+ "safeConfigEditor": "Редактор конфігурації (безпечний режим)",
+ "safeModeDescription": "Фрегат перебуває в безпечному режимі через помилку перевірки конфігурації."
}
diff --git a/web/public/locales/uk/views/events.json b/web/public/locales/uk/views/events.json
index e84c418ec..5b3c20443 100644
--- a/web/public/locales/uk/views/events.json
+++ b/web/public/locales/uk/views/events.json
@@ -12,7 +12,11 @@
"empty": {
"alert": "Немає попереджень для перегляду",
"detection": "Немає ніяких ознак",
- "motion": "Даних про рух не знайдено"
+ "motion": "Даних про рух не знайдено",
+ "recordingsDisabled": {
+ "title": "Записи мають бути ввімкнені",
+ "description": "Елементи рецензування можна створювати для камери, лише якщо для цієї камери ввімкнено запис."
+ }
},
"timeline": "Хронологія",
"timeline.aria": "Вибрати хронiку",
@@ -34,5 +38,30 @@
"label": "Переглянути нові елементи огляду",
"button": "Нові матеріали для перегляду"
},
- "detected": "виявлено"
+ "detected": "виявлено",
+ "suspiciousActivity": "Підозріла активність",
+ "threateningActivity": "Загрозлива діяльність",
+ "detail": {
+ "noDataFound": "Немає детальних даних для перегляду",
+ "aria": "Перемикання детального перегляду",
+ "trackedObject_one": "{{count}} об'єкт",
+ "trackedObject_other": "{{count}} об'єкти",
+ "noObjectDetailData": "Детальні дані про об'єкт недоступні.",
+ "label": "Деталь",
+ "settings": "Налаштування детального перегляду",
+ "alwaysExpandActive": {
+ "title": "Завжди розгортати активне",
+ "desc": "Завжди розгортайте деталі об'єкта активного елемента огляду, якщо вони доступні."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Відстежувана Точка",
+ "clickToSeek": "Натисніть, щоб перейти до цього часу"
+ },
+ "zoomIn": "Збільшити масштаб",
+ "zoomOut": "Зменшити масштаб",
+ "normalActivity": "Звичайний",
+ "needsReview": "Потребує перегляду",
+ "securityConcern": "Проблема безпеки",
+ "select_all": "Усі"
}
diff --git a/web/public/locales/uk/views/explore.json b/web/public/locales/uk/views/explore.json
index cdbcdb6ee..0c7863e05 100644
--- a/web/public/locales/uk/views/explore.json
+++ b/web/public/locales/uk/views/explore.json
@@ -35,7 +35,9 @@
"error": "Не вдалося видалити відстежуваний об'єкт: {{errorMessage}}",
"success": "Відстежуваний об'єкт успішно видалено."
}
- }
+ },
+ "previousTrackedObject": "Попередній відстежуваний об'єкт",
+ "nextTrackedObject": "Наступний відстежуваний об'єкт"
},
"trackedObjectsCount_one": "{{count}} відстежуваний об'єкт ",
"trackedObjectsCount_few": "{{count}} відстежувані об'єкти ",
@@ -101,12 +103,16 @@
"success": {
"updatedLPR": "Номерний знак успішно оновлено.",
"updatedSublabel": "Підмітку успішно оновлено.",
- "regenerate": "Новий опис було запрошено від {{provider}}. Залежно від швидкості вашого провайдера, його перегенерація може зайняти деякий час."
+ "regenerate": "Новий опис було запрошено від {{provider}}. Залежно від швидкості вашого провайдера, його перегенерація може зайняти деякий час.",
+ "audioTranscription": "Запит на аудіотранскрипцію успішно надіслано. Залежно від швидкості вашого сервера Frigate, транскрипція може тривати деякий час.",
+ "updatedAttributes": "Атрибути успішно оновлено."
},
"error": {
"regenerate": "Не вдалося звернутися до {{provider}} для отримання нового опису: {{errorMessage}}",
"updatedSublabelFailed": "Не вдалося оновити підмітку: {{errorMessage}}",
- "updatedLPRFailed": "Не вдалося оновити номерний знак: {{errorMessage}}"
+ "updatedLPRFailed": "Не вдалося оновити номерний знак: {{errorMessage}}",
+ "audioTranscription": "Не вдалося надіслати запит на транскрипцію аудіо: {{errorMessage}}",
+ "updatedAttributesFailed": "Не вдалося оновити атрибути: {{errorMessage}}"
}
},
"button": {
@@ -158,12 +164,23 @@
}
},
"expandRegenerationMenu": "Розгорнути меню регенерації",
- "regenerateFromSnapshot": "Відновити зі знімка"
+ "regenerateFromSnapshot": "Відновити зі знімка",
+ "score": {
+ "label": "Оцінка"
+ },
+ "editAttributes": {
+ "title": "Редагувати атрибути",
+ "desc": "Виберіть атрибути класифікації для цього {{label}}"
+ },
+ "attributes": "Атрибути класифікації",
+ "title": {
+ "label": "Назва"
+ }
},
"dialog": {
"confirmDelete": {
"title": "Підтвердити видалення",
- "desc": "Видалення цього відстежуваного об’єкта призведе до видалення знімка, будь-яких збережених вбудованих елементів та будь-яких пов’язаних записів життєвого циклу об’єкта. Записані кадри цього відстежуваного об’єкта в режимі перегляду історії НЕ будуть видалені.
Ви впевнені, що хочете продовжити?"
+ "desc": "Видалення цього відстежуваного об'єкта призведе до видалення знімка, усіх збережених вбудованих даних та усіх пов'язаних записів деталей відстеження. Записані кадри цього відстежуваного об'єкта в режимі перегляду історії НЕ будуть видалені.
Ви впевнені, що хочете продовжити?"
}
},
"itemMenu": {
@@ -193,6 +210,28 @@
},
"deleteTrackedObject": {
"label": "Видалити цей відстежуваний об'єкт"
+ },
+ "addTrigger": {
+ "label": "Додати тригер",
+ "aria": "Додати тригер для цього відстежуваного об'єкта"
+ },
+ "audioTranscription": {
+ "label": "Транскрибувати",
+ "aria": "Запит на аудіотранскрипцію"
+ },
+ "viewTrackingDetails": {
+ "label": "Переглянути деталі відстеження",
+ "aria": "Показати деталі відстеження"
+ },
+ "showObjectDetails": {
+ "label": "Показати шлях до об'єкта"
+ },
+ "hideObjectDetails": {
+ "label": "Приховати шлях до об'єкта"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Завантажити чистий знімок",
+ "aria": "Завантажити чистий знімок"
}
},
"noTrackedObjects": "Відстежуваних об'єктів не знайдено",
@@ -203,7 +242,64 @@
"details": "деталі",
"snapshot": "знімок",
"video": "відео",
- "object_lifecycle": "життєвий цикл об'єкта"
+ "object_lifecycle": "життєвий цикл об'єкта",
+ "thumbnail": "мініатюра",
+ "tracking_details": "деталі відстеження"
},
- "exploreMore": "Дослідіть більше об'єктів {{label}}"
+ "exploreMore": "Дослідіть більше об'єктів {{label}}",
+ "aiAnalysis": {
+ "title": "Аналіз ШІ"
+ },
+ "concerns": {
+ "label": "Проблеми"
+ },
+ "trackingDetails": {
+ "title": "Деталі відстеження",
+ "noImageFound": "Для цієї позначки часу не знайдено зображення.",
+ "createObjectMask": "Створити маску об'єкта",
+ "adjustAnnotationSettings": "Налаштування параметрів анотацій",
+ "scrollViewTips": "Натисніть, щоб переглянути важливі моменти життєвого циклу цього об'єкта.",
+ "autoTrackingTips": "Положення обмежувальних рамок будуть неточними для камер з автоматичним відстеженням.",
+ "count": "{{first}} з {{second}}",
+ "trackedPoint": "Відстежувана точка",
+ "lifecycleItemDesc": {
+ "visible": "Виявлено {{label}}",
+ "entered_zone": "{{label}} увійшов до {{zones}}",
+ "active": "{{label}} став активним",
+ "stationary": "{{label}} став нерухомим",
+ "attribute": {
+ "faceOrLicense_plate": "Виявлено атрибут {{attribute}} для {{label}}",
+ "other": "{{label}} розпізнано як {{attribute}}"
+ },
+ "gone": "{{label}} залишилося",
+ "heard": "{{label}} почув(ла)",
+ "external": "Виявлено {{label}}",
+ "header": {
+ "zones": "Зони",
+ "ratio": "Співвідношення",
+ "area": "Площа",
+ "score": "Рахунок"
+ }
+ },
+ "annotationSettings": {
+ "title": "Налаштування анотацій",
+ "showAllZones": {
+ "title": "Показати всі зони",
+ "desc": "Завжди показувати зони на кадрах, де об'єкти увійшли в зону."
+ },
+ "offset": {
+ "label": "Зсув анотації",
+ "desc": "Ці дані надходять із каналу виявлення вашої камери, але накладаються на зображення з каналу запису. Малоймовірно, що ці два потоки будуть ідеально синхронізовані. Як результат, обмежувальна рамка та відеоматеріал не будуть ідеально збігатися. Ви можете використовувати це налаштування, щоб змістити анотації вперед або назад у часі, щоб краще узгодити їх із записаним відеоматеріалом.",
+ "millisecondsToOffset": "Мілісекунди для зміщення виявлених анотацій. За замовчуванням: 0",
+ "tips": "Зменште значення, якщо відтворення відео відбувається попереду блоків та точок шляху, і збільште значення, якщо відтворення відео відбувається позаду них. Це значення може бути від’ємним.",
+ "toast": {
+ "success": "Зміщення анотації для {{camera}} було збережено у файлі конфігурації."
+ }
+ }
+ },
+ "carousel": {
+ "previous": "Попередній слайд",
+ "next": "Наступний слайд"
+ }
+ }
}
diff --git a/web/public/locales/uk/views/exports.json b/web/public/locales/uk/views/exports.json
index 55ee0e3e8..6b4108f4d 100644
--- a/web/public/locales/uk/views/exports.json
+++ b/web/public/locales/uk/views/exports.json
@@ -13,5 +13,11 @@
"error": {
"renameExportFailed": "Не вдалося перейменувати експорт: {{errorMessage}}"
}
+ },
+ "tooltip": {
+ "shareExport": "Поділитися експортом",
+ "downloadVideo": "Завантажити відео",
+ "editName": "Редагувати ім'я",
+ "deleteExport": "Видалити експорт"
}
}
diff --git a/web/public/locales/uk/views/faceLibrary.json b/web/public/locales/uk/views/faceLibrary.json
index 34f420704..1170e3ee1 100644
--- a/web/public/locales/uk/views/faceLibrary.json
+++ b/web/public/locales/uk/views/faceLibrary.json
@@ -17,7 +17,7 @@
"trainFailed": "Не вдалося тренуватися: {{errorMessage}}"
},
"success": {
- "updatedFaceScore": "Оцінку обличчя успішно оновлено.",
+ "updatedFaceScore": "Оцінку обличчя успішно оновлено до {{name}} ({{score}}).",
"deletedName_one": "{{count}} Обличчя успішно видалено.",
"deletedName_few": "{{count}} Обличчі успішно видалено.",
"deletedName_many": "{{count}} Облич. успішно видалено.",
@@ -66,12 +66,12 @@
"selectImage": "Будь ласка, виберіть файл зображення."
},
"dropActive": "Скинь зображення сюди…",
- "dropInstructions": "Перетягніть зображення сюди або клацніть, щоб вибрати"
+ "dropInstructions": "Перетягніть або вставте зображення сюди, або клацніть, щоб вибрати"
},
"trainFaceAs": "Тренуйте обличчя як:",
"trainFace": "Обличчя поїзда",
"description": {
- "addFace": "Покрокові інструкції з додавання нової колекції до Бібліотеки облич.",
+ "addFace": "Додайте нову колекцію до Бібліотеки облич, завантаживши своє перше зображення.",
"placeholder": "Введіть назву для цієї колекції",
"invalidName": "Недійсне ім'я. Ім'я може містити лише літери, цифри, пробіли, апострофи, символи підкреслення та дефіси."
},
@@ -83,12 +83,13 @@
"title": "Створити колекцію",
"desc": "Створити нову колекцію",
"new": "Створити нове обличчя",
- "nextSteps": "Щоб створити міцну основу:Використовуйте вкладку «Навчання», щоб вибрати та навчити зображення для кожної виявленої особи. Для найкращих результатів зосередьтеся на зображеннях, спрямованих прямо в обличчя; уникайте навчальних зображень, які фіксують обличчя під кутом. "
+ "nextSteps": "Щоб створити міцну основу:Використовуйте вкладку «Недавні розпізнавання», щоб вибрати та навчити систему розпізнавати зображення для кожної виявленої особи. Для досягнення найкращих результатів зосередьтеся на прямих зображеннях; уникайте навчання зображень, на яких обличчя зняті під кутом. "
},
"train": {
- "title": "Поїзд",
- "aria": "Виберіть поїзд",
- "empty": "Немає останніх спроб розпізнавання обличчя"
+ "title": "Нещодавні визнання",
+ "aria": "Виберіть нещодавні визнання",
+ "empty": "Немає останніх спроб розпізнавання обличчя",
+ "titleShort": "Нещодавні"
},
"collections": "Колекції",
"deleteFaceAttempts": {
diff --git a/web/public/locales/uk/views/live.json b/web/public/locales/uk/views/live.json
index 27a8c518a..f5ef34f2c 100644
--- a/web/public/locales/uk/views/live.json
+++ b/web/public/locales/uk/views/live.json
@@ -10,8 +10,8 @@
"label": "Грати у фоновому режимі",
"desc": "Увімкніть цей параметр, щоб продовжувати потокове передавання, коли програвач приховано."
},
- "tips": "Запустіть ручну подію на основі параметрів збереження запису цієї камери.",
- "title": "Запис на вимогу",
+ "tips": "Завантажте миттєвий знімок або запустіть ручну подію на основі налаштувань збереження запису цієї камери.",
+ "title": "На-вимогу",
"debugView": "Режим зневаджування",
"start": "Почати запис за запитом",
"failedToStart": "Не вдалося запустити ручний запис на вимогу.",
@@ -46,6 +46,9 @@
"lowBandwidth": {
"resetStream": "Скинути потік",
"tips": "Режим перегляду в реальному часі перемикається в економічний режим через помилки буферизації або потоку."
+ },
+ "debug": {
+ "picker": "Вибір потоку недоступний у режимі налагодження. У режимі налагодження завжди використовується потік, якому призначено роль виявлення."
}
},
"muteCameras": {
@@ -85,6 +88,14 @@
"center": {
"label": "Клацніть у кадрі, щоб відцентрувати камеру PTZ"
}
+ },
+ "focus": {
+ "in": {
+ "label": "Фокус PTZ-камери"
+ },
+ "out": {
+ "label": "Вихід PTZ-камери для фокусування"
+ }
}
},
"editLayout": {
@@ -94,7 +105,7 @@
"label": "Редагувати групу камер"
}
},
- "documentTitle": "Прямий трансляція - Frigate",
+ "documentTitle": "Пряма трансляція - Frigate",
"documentTitle.withCamera": "{{camera}} - Пряма трансляція - Frigate",
"lowBandwidthMode": "Економічний режим",
"twoWayTalk": {
@@ -142,7 +153,8 @@
"recording": "Записування",
"snapshots": "Знімки",
"audioDetection": "Виявлення звуку",
- "autotracking": "Автотрекiнг"
+ "autotracking": "Автотрекiнг",
+ "transcription": "Аудіотранскрипція"
},
"history": {
"label": "Показати історичні кадри"
@@ -154,5 +166,34 @@
"active_objects": "Активні об'єкти"
},
"notAllTips": "Ваш {{source}} конфігурацію збереження записів встановлено на режим: {{effectiveRetainMode}}, тому цей запис на вимогу збереже лише сегменти з {{effectiveRetainModeName}}."
+ },
+ "transcription": {
+ "enable": "Увімкнути транскрипцію аудіо в реальному часі",
+ "disable": "Вимкнути транскрипцію аудіо в реальному часі"
+ },
+ "noCameras": {
+ "title": "Немає налаштованих камер",
+ "description": "Почніть з підключення камери до Frigate.",
+ "buttonText": "Додати камеру",
+ "restricted": {
+ "title": "Немає Доступних Камер",
+ "description": "У вас немає дозволу на перегляд будь-яких камер у цій групі."
+ },
+ "default": {
+ "title": "Немає Налаштованих Камер",
+ "description": "Почніть з підключення камери до Frigate.",
+ "buttonText": "Додати Камеру"
+ },
+ "group": {
+ "title": "Немає камер у групі",
+ "description": "Цій групі камер не призначено або не ввімкнено камер.",
+ "buttonText": "Керування групами"
+ }
+ },
+ "snapshot": {
+ "takeSnapshot": "Завантажити миттєвий знімок",
+ "noVideoSource": "Немає доступного джерела відео для знімка.",
+ "captureFailed": "Не вдалося зробити знімок.",
+ "downloadStarted": "Розпочато завантаження знімка."
}
}
diff --git a/web/public/locales/uk/views/search.json b/web/public/locales/uk/views/search.json
index 0d8657e3d..052b4c457 100644
--- a/web/public/locales/uk/views/search.json
+++ b/web/public/locales/uk/views/search.json
@@ -34,7 +34,8 @@
"max_speed": "Максимальна швидкість",
"recognized_license_plate": "Розпізнаний номерний знак",
"has_clip": "Має клiп",
- "has_snapshot": "Має знiмок"
+ "has_snapshot": "Має знiмок",
+ "attributes": "Атрибути"
},
"searchType": {
"thumbnail": "Мініатюра",
diff --git a/web/public/locales/uk/views/settings.json b/web/public/locales/uk/views/settings.json
index a5e7d511f..e9bc0dd42 100644
--- a/web/public/locales/uk/views/settings.json
+++ b/web/public/locales/uk/views/settings.json
@@ -86,7 +86,45 @@
"title": "Огляд",
"desc": "Тимчасово ввімкнути/вимкнути сповіщення та виявлення для цієї камери до перезавантаження Frigate. Якщо вимкнено, нові елементи огляду не створюватимуться. "
},
- "title": "Налаштування камери"
+ "title": "Налаштування камери",
+ "object_descriptions": {
+ "title": "Генеративні описи об'єктів штучного інтелекту",
+ "desc": "Тимчасово ввімкнути/вимкнути генеративні описи об'єктів ШІ для цієї камери. Якщо вимкнено, згенеровані ШІ описи не запитуватимуться для об'єктів, що відстежуються на цій камері."
+ },
+ "review_descriptions": {
+ "title": "Описи генеративного ШІ-огляду",
+ "desc": "Тимчасово ввімкнути/вимкнути генеративні описи огляду за допомогою штучного інтелекту для цієї камери. Якщо вимкнено, для елементів огляду на цій камері не запитуватимуться згенеровані штучним інтелектом описи."
+ },
+ "addCamera": "Додати нову камеру",
+ "editCamera": "Редагувати камеру:",
+ "selectCamera": "Виберіть камеру",
+ "backToSettings": "Назад до налаштувань камери",
+ "cameraConfig": {
+ "add": "Додати камеру",
+ "edit": "Редагувати камеру",
+ "description": "Налаштуйте параметри камери, включаючи потокові входи та ролі.",
+ "name": "Назва камери",
+ "nameRequired": "Потрібно вказати назву камери",
+ "nameInvalid": "Назва камери повинна містити лише літери, цифри, символи підкреслення або дефіси",
+ "namePlaceholder": "наприклад, вхідні_двері",
+ "enabled": "Увімкнено",
+ "ffmpeg": {
+ "inputs": "Вхідні потоки",
+ "path": "Шлях потоку",
+ "pathRequired": "Шлях потоку обов'язковий",
+ "pathPlaceholder": "'rtsp://...",
+ "roles": "Ролі",
+ "rolesRequired": "Потрібна хоча б одна роль",
+ "rolesUnique": "Кожна роль (аудіо, виявлення, запис) може бути призначена лише одному потоку",
+ "addInput": "Додати вхідний потік",
+ "removeInput": "Вилучити вхідний потік",
+ "inputsRequired": "Потрібен принаймні один вхідний потік"
+ },
+ "toast": {
+ "success": "Камеру {{cameraName}} успішно збережено"
+ },
+ "nameLength": "Назва камери має містити менше 24 символів."
+ }
},
"masksAndZones": {
"motionMasks": {
@@ -104,8 +142,8 @@
"edit": "Редагувати маску руху",
"toast": {
"success": {
- "title": "{{polygonName}} збережено. Перезапустіть Frigate, щоб застосувати зміни.",
- "noName": "Маску руху збережено. Перезапустіть Frigate, щоб застосувати зміни."
+ "title": "{{polygonName}} збережено.",
+ "noName": "Маску руху збережено."
}
},
"label": "Маска руху",
@@ -123,7 +161,7 @@
"name": {
"inputPlaceHolder": "Введіть назву…",
"title": "Ім'я",
- "tips": "Назва має містити щонайменше 2 символи та не повинна бути назвою камери чи іншої зони."
+ "tips": "Назва має містити щонайменше 2 символи, принаймні одну літеру та не повинна бути назвою камери чи іншої зони на цій камері."
},
"desc": {
"title": "Зони дозволяють визначити певну область кадру, щоб ви могли визначити, чи знаходиться об'єкт у певній області.",
@@ -169,7 +207,7 @@
"desc": "Список об'єктів, що належать до цієї зони."
},
"toast": {
- "success": "Зону ({{zoneName}}) збережено. Перезапустіть Frigate, щоб застосувати зміни."
+ "success": "Зону ({{zoneName}}) збережено."
}
},
"objectMasks": {
@@ -192,8 +230,8 @@
},
"toast": {
"success": {
- "title": "{{polygonName}} збережено. Перезапустіть Frigate, щоб застосувати зміни.",
- "noName": "Маску об'єкта збережено. Перезапустіть Frigate, щоб застосувати зміни."
+ "title": "{{polygonName}} збережено.",
+ "noName": "Маску об'єкта збережено."
}
},
"label": "Маски об'єктів"
@@ -214,7 +252,8 @@
"mustNotContainPeriod": "Назва зони не повинна містити крапок.",
"mustNotBeSameWithCamera": "Назва зони не повинна збігатися з назвою камери.",
"mustBeAtLeastTwoCharacters": "Назва зони має містити щонайменше 2 символи.",
- "hasIllegalCharacter": "Назва зони містить недопустимі символи."
+ "hasIllegalCharacter": "Назва зони містить недопустимі символи.",
+ "mustHaveAtLeastOneLetter": "Назва зони повинна містити щонайменше одну літеру."
}
},
"polygonDrawing": {
@@ -308,7 +347,20 @@
"tips": "Поля руху
Червоні поля будуть накладені на області кадру, де наразі виявляється рух
"
},
"objectList": "Список об'єктів",
- "noObjects": "Без об'єктів"
+ "noObjects": "Без об'єктів",
+ "paths": {
+ "title": "Шляхи",
+ "desc": "Показувати важливі точки шляху відстежуваного об'єкта",
+ "tips": "Шляхи
Лінії та кола позначатимуть важливі точки, які відстежуваний об'єкт переміщував протягом свого життєвого циклу.
"
+ },
+ "audio": {
+ "title": "Аудіо",
+ "noAudioDetections": "Немає виявлення звуку",
+ "score": "рахунок",
+ "currentRMS": "Поточне середньоквадратичне значення",
+ "currentdbFS": "Поточний dbFS"
+ },
+ "openCameraWebUI": "Відкрийте веб-інтерфейс {{camera}}"
},
"classification": {
"licensePlateRecognition": {
@@ -383,7 +435,7 @@
"supportedDetectors": "Підтримувані детектори",
"error": "Не вдалося завантажити інформацію про модель",
"availableModels": "Доступні моделі",
- "trainDate": "Дата поїзда",
+ "trainDate": "Дата тренування",
"baseModel": "Базова модель",
"modelSelect": "Тут можна вибрати доступні моделі на Frigate+. Зверніть увагу, що можна вибрати лише моделі, сумісні з вашою поточною конфігурацією детектора.",
"title": "Інформація про модель",
@@ -426,7 +478,7 @@
"monday": "Понеділок"
}
},
- "title": "Загальна налаштування",
+ "title": "Налаштування інтерфейсу користувача",
"liveDashboard": {
"title": "Панель керування в прямому ефірі",
"automaticLiveView": {
@@ -436,6 +488,14 @@
"playAlertVideos": {
"label": "Відтворити відео зі сповіщеннями",
"desc": "За замовчуванням останні сповіщення на панелі керування Live відтворюються як невеликі відеозаписи, що циклічно відтворюються. Вимкніть цю опцію, щоб відображати лише статичне зображення останніх сповіщень на цьому пристрої/у браузері."
+ },
+ "displayCameraNames": {
+ "label": "Завжди показувати назви камер",
+ "desc": "Завжди відображати назви камер у чіпі на панелі керування режимом живого перегляду з кількох камер."
+ },
+ "liveFallbackTimeout": {
+ "label": "Час очікування резервного програвача в реальному часі",
+ "desc": "Коли високоякісна пряма трансляція з камери недоступна, повернутися до режиму низької пропускної здатності через певну кількість секунд. За замовчуванням: 3."
}
},
"storedLayouts": {
@@ -498,9 +558,11 @@
"classification": "Налаштування класифікації – Фрегат",
"masksAndZones": "Редактор масок та зон – Фрегат",
"motionTuner": "Тюнер руху - Фрегат",
- "general": "Основна налаштування – Frigate",
+ "general": "Основна Статус – Frigate",
"frigatePlus": "Налаштування Frigate+ – Frigate",
- "enrichments": "Налаштуваннях збагачення – Frigate"
+ "enrichments": "Налаштуваннях збагачення – Frigate",
+ "cameraManagement": "Керування камерами - Frigate",
+ "cameraReview": "Налаштування перегляду камери - Frigate"
},
"menu": {
"ui": "Інтерфейс користувача",
@@ -512,7 +574,11 @@
"debug": "Налагодження",
"notifications": "Сповіщення",
"frigateplus": "Frigate+",
- "enrichments": "Збагачення"
+ "enrichments": "Збагаченням",
+ "triggers": "Тригери",
+ "roles": "Ролі",
+ "cameraManagement": "Управління",
+ "cameraReview": "Огляду"
},
"dialog": {
"unsavedChanges": {
@@ -530,7 +596,7 @@
"desc": "Керувати обліковими записами користувачів цього екземпляра Frigate."
},
"addUser": "Додати користувача",
- "updatePassword": "Оновити пароль",
+ "updatePassword": "Скинути пароль",
"toast": {
"success": {
"deleteUser": "Користувач {{user}} успішно видалений",
@@ -546,7 +612,7 @@
}
},
"table": {
- "password": "Пароль",
+ "password": "Скинути пароль",
"deleteUser": "Видалити користувача",
"username": "Ім'я користувача",
"actions": "Дії",
@@ -576,6 +642,15 @@
"confirm": {
"title": "Підтвердьте пароль",
"placeholder": "Підтвердьте пароль"
+ },
+ "show": "Показати пароль",
+ "hide": "Приховати пароль",
+ "requirements": {
+ "title": "Вимоги до пароля:",
+ "length": "Принаймні 8 символів",
+ "uppercase": "Принаймні одна велика літера",
+ "digit": "Принаймні одна цифра",
+ "special": "Принаймні один спеціальний символ (!@#$%^&*(),.?\":{}|<>)"
}
},
"newPassword": {
@@ -586,7 +661,11 @@
"placeholder": "Введіть новий пароль"
},
"usernameIsRequired": "Потрібне ім'я користувача",
- "passwordIsRequired": "Потрібен пароль"
+ "passwordIsRequired": "Потрібен пароль",
+ "currentPassword": {
+ "title": "Поточний пароль",
+ "placeholder": "Введіть свій поточний пароль"
+ }
},
"changeRole": {
"roleInfo": {
@@ -594,7 +673,8 @@
"intro": "Виберіть відповідну роль для цього користувача:",
"adminDesc": "Повний доступ до всіх функцій.",
"viewer": "Глядач",
- "viewerDesc": "Обмежено лише активними інформаційними панелями, функціями «Огляд», «Дослідження» та «Експорт»."
+ "viewerDesc": "Обмежено лише активними інформаційними панелями, функціями «Огляд», «Дослідження» та «Експорт».",
+ "customDesc": "Особлива роль з доступом до певної камери."
},
"title": "Змінити роль користувача",
"desc": "Оновити дозволи для {{username}}",
@@ -616,7 +696,12 @@
"setPassword": "Встановити пароль",
"desc": "Створіть надійний пароль для захисту цього облікового запису.",
"cannotBeEmpty": "Пароль не може бути порожнім",
- "doNotMatch": "Паролі не збігаються"
+ "doNotMatch": "Паролі не збігаються",
+ "currentPasswordRequired": "Потрібно ввести поточний пароль",
+ "incorrectCurrentPassword": "Поточний пароль неправильний",
+ "passwordVerificationFailed": "Не вдалося перевірити пароль",
+ "multiDeviceWarning": "На будь-яких інших пристроях, на яких ви ввійшли в систему, потрібно буде повторно ввійти протягом {{refresh_time}}.",
+ "multiDeviceAdmin": "Ви також можете змусити всіх користувачів негайно повторно автентифікуватися, змінивши свій JWT-секрет."
}
},
"title": "Користувачі"
@@ -681,6 +766,548 @@
"desc": "Класифікація птахів ідентифікує відомих птахів за допомогою квантованої моделі тензорного потоку. Коли відомого птаха розпізнано, його загальну назву буде додано як підмітку. Ця інформація відображається в інтерфейсі, фільтрах, а також у сповіщеннях.",
"title": "Класифікація птахів"
},
- "title": "Налаштуваннях збагачення"
+ "title": "Налаштуваннях Збагаченням"
+ },
+ "triggers": {
+ "documentTitle": "Тригери",
+ "management": {
+ "title": "Тригери",
+ "desc": "Керуйте тригерами для {{camera}}. Використовуйте тип мініатюри для спрацьовування на схожих мініатюрах до вибраного об’єкта відстеження, а тип опису – для спрацьовування на схожих описах до вказаного вами тексту."
+ },
+ "addTrigger": "Додати Тригер",
+ "table": {
+ "name": "Ім'я",
+ "type": "Тип",
+ "content": "Зміст",
+ "threshold": "Поріг",
+ "actions": "Дії",
+ "noTriggers": "Для цієї камери не налаштовано жодних тригерів.",
+ "edit": "Редагувати",
+ "deleteTrigger": "Видалити тригер",
+ "lastTriggered": "Остання активація"
+ },
+ "type": {
+ "thumbnail": "Мініатюра",
+ "description": "Опис"
+ },
+ "actions": {
+ "alert": "Позначити як сповіщення",
+ "notification": "Надіслати сповіщення",
+ "sub_label": "Додати підмітку",
+ "attribute": "Додати атрибут"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "Створити тригер",
+ "desc": "Створіть тригер для камери {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Редагувати тригер",
+ "desc": "Редагувати налаштування для тригера на камері {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Видалити тригер",
+ "desc": "Ви впевнені, що хочете видалити тригер {{triggerName}}? Цю дію не можна скасувати."
+ },
+ "form": {
+ "name": {
+ "title": "Ім'я",
+ "placeholder": "Назвіть цей тригер",
+ "error": {
+ "minLength": "Поле має містити щонайменше 2 символи.",
+ "invalidCharacters": "Поле може містити лише літери, цифри, символи підкреслення та дефіси.",
+ "alreadyExists": "Тригер із такою назвою вже існує для цієї камери."
+ },
+ "description": "Введіть унікальну назву або опис, щоб ідентифікувати цей тригер"
+ },
+ "enabled": {
+ "description": "Увімкнути або вимкнути цей тригер"
+ },
+ "type": {
+ "title": "Тип",
+ "placeholder": "Виберіть тип тригера",
+ "description": "Спрацьовує, коли виявляється схожий опис відстежуваного об'єкта",
+ "thumbnail": "Спрацьовує, коли виявляється мініатюра схожого відстежуваного об'єкта"
+ },
+ "content": {
+ "title": "Зміст",
+ "imagePlaceholder": "Виберіть мініатюру",
+ "textPlaceholder": "Введіть текстовий вміст",
+ "imageDesc": "Відображаються лише 100 останніх мініатюр. Якщо ви не можете знайти потрібну мініатюру, перегляньте попередні об’єкти в розділі «Огляд» і налаштуйте тригер у меню.",
+ "textDesc": "Введіть текст, щоб запустити цю дію, коли буде виявлено схожий опис відстежуваного об’єкта.",
+ "error": {
+ "required": "Контент обов'язковий."
+ }
+ },
+ "threshold": {
+ "title": "Поріг",
+ "error": {
+ "min": "Поріг має бути щонайменше 0",
+ "max": "Поріг має бути не більше 1"
+ },
+ "desc": "Встановіть поріг подібності для цього тригера. Вищий поріг означає, що для спрацьовування тригера потрібна ближча відповідність."
+ },
+ "actions": {
+ "title": "Дії",
+ "desc": "За замовчуванням Frigate надсилає повідомлення MQTT для всіх тригерів. Підмітки додають назву тригера до мітки об'єкта. Атрибути – це метадані, які можна шукати, що зберігаються окремо в метаданих відстежуваного об'єкта.",
+ "error": {
+ "min": "Потрібно вибрати принаймні одну дію."
+ }
+ },
+ "friendly_name": {
+ "title": "Зрозуміле ім'я",
+ "placeholder": "Назвіть або опишіть цей тригер",
+ "description": "Зрозуміла назва або описовий текст (необов'язково) для цього тригера."
+ }
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Тригер {{name}} успішно створено.",
+ "updateTrigger": "Тригер {{name}} успішно оновлено.",
+ "deleteTrigger": "Тригер {{name}} успішно видалено."
+ },
+ "error": {
+ "createTriggerFailed": "Не вдалося створити тригер: {{errorMessage}}",
+ "updateTriggerFailed": "Не вдалося оновити тригер: {{errorMessage}}",
+ "deleteTriggerFailed": "Не вдалося видалити тригер: {{errorMessage}}"
+ }
+ },
+ "semanticSearch": {
+ "title": "Семантичний пошук вимкнено",
+ "desc": "Для використання тригерів необхідно ввімкнути семантичний пошук."
+ },
+ "wizard": {
+ "title": "Створити тригер",
+ "step1": {
+ "description": "Налаштуйте основні параметри для вашого тригера."
+ },
+ "step2": {
+ "description": "Налаштуйте контент, який запускатиме цю дію."
+ },
+ "step3": {
+ "description": "Налаштуйте поріг та дії для цього тригера."
+ },
+ "steps": {
+ "nameAndType": "Ім'я та тип",
+ "configureData": "Налаштувати дані",
+ "thresholdAndActions": "Поріг та дії"
+ }
+ }
+ },
+ "roles": {
+ "addRole": "Додати роль",
+ "table": {
+ "role": "Роль",
+ "cameras": "Камери",
+ "actions": "Дії",
+ "noRoles": "Не знайдено користувацьких ролей.",
+ "editCameras": "Редагувати камери",
+ "deleteRole": "Видалити роль"
+ },
+ "toast": {
+ "success": {
+ "createRole": "Роль {{role}} успішно створена",
+ "updateCameras": "Камери оновлено для ролі {{role}}",
+ "deleteRole": "Роль {{role}} успішно видалено",
+ "userRolesUpdated_one": "{{count}} користувача, призначену цій ролі, оновлено до «глядача», який має доступ до всіх камер.",
+ "userRolesUpdated_few": "{{count}} Користувачі, яким призначено цю роль, оновлено до ролі «глядача», що має доступ до всіх камер.",
+ "userRolesUpdated_many": "{{count}} Користувачів, яким призначено цю роль, оновлено до ролі «глядача», що має доступ до всіх камер."
+ },
+ "error": {
+ "createRoleFailed": "Не вдалося створити роль: {{errorMessage}}",
+ "updateCamerasFailed": "Не вдалося оновити камери: {{errorMessage}}",
+ "deleteRoleFailed": "Не вдалося видалити роль: {{errorMessage}}",
+ "userUpdateFailed": "Не вдалося оновити ролі користувачів: {{errorMessage}}"
+ }
+ },
+ "management": {
+ "title": "Керування ролями глядача",
+ "desc": "Керуйте ролями глядачів та їхніми дозволами на доступ до камери для цього екземпляра Frigate."
+ },
+ "dialog": {
+ "createRole": {
+ "title": "Створити нову роль",
+ "desc": "Додайте нову роль і вкажіть дозволи доступу до камери."
+ },
+ "editCameras": {
+ "title": "Редагувати рольові камери",
+ "desc": "Оновіть доступ до камери для цієї ролі {{role}}."
+ },
+ "deleteRole": {
+ "title": "Видалити роль",
+ "desc": "Цю дію не можна скасувати. Це призведе до остаточного видалення ролі та призначення всім користувачам із цією роллю ролі «глядач», що надасть глядачеві доступ до всіх камер.",
+ "warn": "Ви впевнені, що хочете видалити {{role}}?",
+ "deleting": "Видалення..."
+ },
+ "form": {
+ "role": {
+ "title": "Назва ролі",
+ "placeholder": "Введіть назву ролі",
+ "desc": "Дозволено використовувати лише літери, цифри, крапки та символи підкреслення.",
+ "roleIsRequired": "Потрібно вказати назву ролі",
+ "roleOnlyInclude": "Назва ролі може містити лише літери, цифри, символи *.* або *.*",
+ "roleExists": "Роль із такою назвою вже існує."
+ },
+ "cameras": {
+ "title": "Камери",
+ "desc": "Виберіть камери, до яких ця роль має доступ. Потрібна принаймні одна камера.",
+ "required": "Потрібно вибрати принаймні одну камеру."
+ }
+ }
+ }
+ },
+ "cameraWizard": {
+ "title": "Додати камеру",
+ "description": "Виконайте наведені нижче кроки, щоб додати нову камеру до вашої установки Frigate.",
+ "steps": {
+ "nameAndConnection": "Ім'я та з'єднання",
+ "streamConfiguration": "Конфігурація потоку",
+ "validationAndTesting": "Валідація та тестування",
+ "probeOrSnapshot": "Зонд або знімок"
+ },
+ "save": {
+ "success": "Нову камеру успішно збережено {{cameraName}}.",
+ "failure": "Помилка збереження {{cameraName}}."
+ },
+ "testResultLabels": {
+ "resolution": "Роздільна здатність",
+ "video": "Відео",
+ "audio": "Аудіо",
+ "fps": "FPS"
+ },
+ "commonErrors": {
+ "noUrl": "Будь ласка, надайте дійсну URL-адресу потоку",
+ "testFailed": "Тест потоку не вдався: {{error}}"
+ },
+ "step1": {
+ "description": "Введіть дані вашої камери та виберіть тестування камери або виберіть бренд вручну.",
+ "cameraName": "Назва камери",
+ "cameraNamePlaceholder": "наприклад, передні_двері або огляд заднього двору",
+ "host": "Хост/IP-адреса",
+ "port": "Порт",
+ "username": "Ім'я користувача",
+ "usernamePlaceholder": "Необов'язково",
+ "password": "Пароль",
+ "passwordPlaceholder": "Необов'язково",
+ "selectTransport": "Виберіть транспортний протокол",
+ "cameraBrand": "Бренд камери",
+ "selectBrand": "Виберіть марку камери для шаблону URL-адреси",
+ "customUrl": "URL-адреса користувацького потоку",
+ "brandInformation": "Інформація про бренд",
+ "brandUrlFormat": "Для камер з форматом RTSP URL, як: {{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "testConnection": "Тестове з'єднання",
+ "testSuccess": "Тестування з'єднання успішне!",
+ "testFailed": "Перевірка з’єднання не вдалася. Перевірте введені дані та повторіть спробу.",
+ "streamDetails": "Деталі трансляції",
+ "warnings": {
+ "noSnapshot": "Не вдалося отримати знімок із налаштованого потоку."
+ },
+ "errors": {
+ "brandOrCustomUrlRequired": "Виберіть або марку камери з хостом/IP-адресою, або виберіть «Інше» з власною URL-адресою",
+ "nameRequired": "Потрібно вказати назву камери",
+ "nameLength": "Назва камери має містити не більше 64 символів",
+ "invalidCharacters": "Назва камери містить недійсні символи",
+ "nameExists": "Назва камери вже існує",
+ "brands": {
+ "reolink-rtsp": "Не рекомендується використовувати Reolink RTSP. Увімкніть HTTP у налаштуваннях прошивки камери та перезапустіть майстер."
+ },
+ "customUrlRtspRequired": "Користувацькі URL-адреси мають починатися з \"rtsp://\". Для потоків з камер, що не підтримують RTSP, потрібне ручне налаштування."
+ },
+ "docs": {
+ "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras"
+ },
+ "testing": {
+ "probingMetadata": "Зондування метаданих камери...",
+ "fetchingSnapshot": "Отримання знімка камери..."
+ },
+ "connectionSettings": "Налаштування підключення",
+ "detectionMethod": "Метод виявлення потоку",
+ "onvifPort": "Порт ONVIF",
+ "probeMode": "Зонд-камера",
+ "manualMode": "Ручний вибір",
+ "detectionMethodDescription": "Перевірте камеру з ONVIF (якщо підтримується) для пошуку URL-адресів потоку камери або вручну виберіть бренд камери, щоб використовувати попередньо визначені URL. Щоб введіти налаштований URL-адрес RTSP, виберіть ручний метод і вибрати \"Інший\".",
+ "onvifPortDescription": "Для камер, що підтримують ONVIF, це зазвичай 80 або 8080.",
+ "useDigestAuth": "Використовувати дайджест-автентифікацію",
+ "useDigestAuthDescription": "Використовуйте автентифікацію HTTP-дайджест для ONVIF. Деякі камери можуть вимагати спеціальне ім’я користувача/пароль ONVIF замість стандартного користувача-адміністратора."
+ },
+ "step2": {
+ "description": "Перевірте камеру на наявність доступних потоків або налаштуйте ручні параметри на основі вибраного методу виявлення.",
+ "streamsTitle": "Потоки з камери",
+ "addStream": "Додати потік",
+ "addAnotherStream": "Додати ще один потік",
+ "streamTitle": "Потік {{number}}",
+ "streamUrl": "URL-адреса потоку",
+ "streamUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "url": "URL",
+ "resolution": "Роздільна здатність",
+ "selectResolution": "Виберіть роздільну здатність",
+ "quality": "Якість",
+ "selectQuality": "Виберіть якість",
+ "roles": "Ролі",
+ "roleLabels": {
+ "detect": "Виявлення об'єктів",
+ "record": "Запис",
+ "audio": "Аудіо"
+ },
+ "testStream": "Тестове з'єднання",
+ "testSuccess": "Тестування з'єднання успішне!",
+ "testFailed": "Перевірка з’єднання не вдалася. Перевірте введені дані та повторіть спробу.",
+ "testFailedTitle": "Тест не вдався",
+ "connected": "Підключено",
+ "notConnected": "Не підключено",
+ "featuresTitle": "Особливості",
+ "go2rtc": "Зменште кількість підключень до камери",
+ "detectRoleWarning": "Для продовження принаймні один потік повинен мати роль \"виявлення\".",
+ "rolesPopover": {
+ "title": "Ролі потоку",
+ "detect": "Основний канал для виявлення об'єктів.",
+ "record": "Зберігає сегменти відеоканалу на основі налаштувань конфігурації.",
+ "audio": "Стрічка даних для виявлення на основі аудіо."
+ },
+ "featuresPopover": {
+ "title": "Функції потоку",
+ "description": "Використовуйте ретрансляцію go2rtc, щоб зменшити кількість підключень до вашої камери."
+ },
+ "streamDetails": "Деталі трансляції",
+ "probing": "Зондуюча камера...",
+ "retry": "Повторити спробу",
+ "testing": {
+ "probingMetadata": "Зондування метаданих камери...",
+ "fetchingSnapshot": "Отримання знімка камери..."
+ },
+ "probeFailed": "Не вдалося дослідити камеру: {{error}}",
+ "probingDevice": "Зондуючий пристрій...",
+ "probeSuccessful": "Зонд успішно",
+ "probeError": "Помилка зонда",
+ "probeNoSuccess": "Зондування Невдало",
+ "deviceInfo": "Інформація про пристрій",
+ "manufacturer": "Виробник",
+ "model": "Модель",
+ "firmware": "Прошивка",
+ "profiles": "Профілі",
+ "ptzSupport": "Підтримка PTZ-камер",
+ "autotrackingSupport": "Підтримка автоматичного відстеження",
+ "presets": "Пресети",
+ "rtspCandidates": "Кандидати RTSP",
+ "rtspCandidatesDescription": "З камери було знайдено такі URL-адреси RTSP. Перевірте з’єднання, щоб переглянути метадані потоку.",
+ "noRtspCandidates": "Не знайдено URL-адрес RTSP з камери. Ваші облікові дані можуть бути неправильними, або камера може не підтримувати ONVIF чи метод, який використовується для отримання URL-адрес RTSP. Поверніться та введіть URL-адресу RTSP вручну.",
+ "candidateStreamTitle": "Кандидат {{number}}",
+ "useCandidate": "Використання",
+ "uriCopy": "Копіювати",
+ "uriCopied": "URI скопійовано в буфер обміну",
+ "testConnection": "Тестове з'єднання",
+ "toggleUriView": "Натисніть, щоб перемкнути повний вигляд URI",
+ "errors": {
+ "hostRequired": "Потрібно вказати хост/IP-адресу"
+ }
+ },
+ "step3": {
+ "description": "Налаштуйте ролі потоків та додайте додаткові потоки для вашої камери.",
+ "validationTitle": "Перевірка потоку",
+ "connectAllStreams": "Підключити всі потоки",
+ "reconnectionSuccess": "Повторне підключення успішне.",
+ "reconnectionPartial": "Не вдалося відновити підключення до деяких потоків.",
+ "streamUnavailable": "Попередній перегляд трансляції недоступний",
+ "reload": "Перезавантажити",
+ "connecting": "Підключення...",
+ "streamTitle": "Потік {{number}}",
+ "valid": "Дійсний",
+ "failed": "Не вдалося",
+ "notTested": "Не тестувалося",
+ "connectStream": "Підключитися",
+ "connectingStream": "Підключення",
+ "disconnectStream": "Відключитися",
+ "estimatedBandwidth": "Орієнтовна пропускна здатність",
+ "roles": "Ролі",
+ "none": "Жоден",
+ "error": "Помилка",
+ "streamValidated": "Потік {{number}} успішно перевірено",
+ "streamValidationFailed": "Не вдалося перевірити потік {{number}}",
+ "saveAndApply": "Зберегти нову камеру",
+ "saveError": "Недійсна конфігурація. Перевірте свої налаштування.",
+ "issues": {
+ "title": "Перевірка потоку",
+ "videoCodecGood": "Відеокодек: {{codec}}.",
+ "audioCodecGood": "Аудіокодек: {{codec}}.",
+ "noAudioWarning": "Для цього потоку не виявлено аудіо, записи не матимуть аудіо.",
+ "audioCodecRecordError": "Для підтримки аудіо в записах потрібен аудіокодек AAC.",
+ "audioCodecRequired": "Для підтримки виявлення звуку потрібен аудіопотік.",
+ "restreamingWarning": "Зменшення кількості підключень до камери для потоку запису може дещо збільшити використання процесора.",
+ "dahua": {
+ "substreamWarning": "Підпотік 1 заблокований на низькій роздільній здатності. Багато камер Dahua / Amcrest / EmpireTech підтримують додаткові підпотоки, які потрібно ввімкнути в налаштуваннях камери. Рекомендується перевірити та використовувати ці потоки, якщо вони доступні."
+ },
+ "hikvision": {
+ "substreamWarning": "Підпотік 1 заблокований на низькій роздільній здатності. Багато камер Hikvision підтримують додаткові підпотоки, які потрібно ввімкнути в налаштуваннях камери. Рекомендується перевірити та використовувати ці потоки, якщо вони доступні."
+ },
+ "resolutionHigh": "Роздільна здатність {{resolution}} може призвести до збільшення використання ресурсів.",
+ "resolutionLow": "Роздільна здатність {{resolution}} може бути занадто низькою для надійного виявлення малих об'єктів."
+ },
+ "ffmpegModule": "Використовувати режим сумісності з потоками",
+ "ffmpegModuleDescription": "Якщо потік не завантажується після кількох спроб, спробуйте ввімкнути цю функцію. Коли вона ввімкнена, Frigate використовуватиме модуль ffmpeg з go2rtc. Це може забезпечити кращу сумісність з деякими потоками камер.",
+ "streamsTitle": "Трансляції з камери",
+ "addStream": "Додати потік",
+ "addAnotherStream": "Додати ще один потік",
+ "streamUrl": "URL-адреса потоку",
+ "streamUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "selectStream": "Виберіть потік",
+ "searchCandidates": "Пошук кандидатів...",
+ "noStreamFound": "Потік не знайдено",
+ "url": "URL",
+ "resolution": "Роздільна здатність",
+ "selectResolution": "Виберіть роздільну здатність",
+ "quality": "Якість",
+ "selectQuality": "Виберіть якість",
+ "roleLabels": {
+ "detect": "Виявлення об'єктів",
+ "record": "Запис",
+ "audio": "Аудіо"
+ },
+ "testStream": "Тестове з'єднання",
+ "testSuccess": "Тестування трансляції успішне!",
+ "testFailed": "Тест потоку не вдався",
+ "testFailedTitle": "Тест не вдався",
+ "connected": "Підключено",
+ "notConnected": "Не підключено",
+ "featuresTitle": "Особливості",
+ "go2rtc": "Зменште кількість підключень до камери",
+ "detectRoleWarning": "Для продовження принаймні один потік повинен мати роль \"виявлення\".",
+ "rolesPopover": {
+ "title": "Ролі потоку",
+ "detect": "Основний канал для виявлення об'єктів.",
+ "record": "Зберігає сегменти відеоканалу на основі налаштувань конфігурації.",
+ "audio": "Стрічка даних для виявлення на основі аудіо."
+ },
+ "featuresPopover": {
+ "title": "Функції потоку",
+ "description": "Використовуйте ретрансляцію go2rtc, щоб зменшити кількість підключень до вашої камери."
+ }
+ },
+ "step4": {
+ "description": "Фінальна перевірка та аналіз перед збереженням нової камери. Підключіть кожен потік перед збереженням.",
+ "validationTitle": "Перевірка потоку",
+ "connectAllStreams": "Підключити всі потоки",
+ "reconnectionSuccess": "Повторне підключення успішне.",
+ "reconnectionPartial": "Не вдалося відновити підключення до деяких потоків.",
+ "streamUnavailable": "Попередній перегляд трансляції недоступний",
+ "reload": "Перезавантажити",
+ "connecting": "Підключення...",
+ "streamTitle": "Потік {{number}}",
+ "valid": "Дійсний",
+ "failed": "Не вдалося",
+ "notTested": "Не тестувалося",
+ "connectStream": "Підключитися",
+ "connectingStream": "Підключення",
+ "disconnectStream": "Відключитися",
+ "estimatedBandwidth": "Орієнтовна пропускна здатність",
+ "roles": "Ролі",
+ "ffmpegModule": "Використовувати режим сумісності з потоками",
+ "ffmpegModuleDescription": "Якщо потік не завантажується після кількох спроб, спробуйте ввімкнути цю функцію. Коли вона ввімкнена, Frigate використовуватиме модуль ffmpeg з go2rtc. Це може забезпечити кращу сумісність з деякими потоками камер.",
+ "none": "Жоден",
+ "error": "Помилка",
+ "streamValidated": "Потік {{number}} успішно перевірено",
+ "streamValidationFailed": "Не вдалося перевірити потік {{number}}",
+ "saveAndApply": "Зберегти нову камеру",
+ "saveError": "Недійсна конфігурація. Перевірте свої налаштування.",
+ "issues": {
+ "title": "Перевірка потоку",
+ "videoCodecGood": "Відеокодек є {{codec}}.",
+ "audioCodecGood": "Аудіокодек є {{codec}}.",
+ "resolutionHigh": "Роздільна здатність {{resolution}} може призвести до збільшення використання ресурсів.",
+ "resolutionLow": "Роздільна здатність {{resolution}} може бути занадто низькою для надійного виявлення малих об'єктів.",
+ "noAudioWarning": "Для цього потоку не виявлено аудіо, записи не матимуть аудіо.",
+ "audioCodecRecordError": "Для підтримки аудіо в записах потрібен аудіокодек AAC.",
+ "audioCodecRequired": "Для підтримки виявлення звуку потрібен аудіопотік.",
+ "restreamingWarning": "Зменшення кількості підключень до камери для потоку запису може дещо збільшити використання процесора.",
+ "brands": {
+ "reolink-rtsp": "Не рекомендується використовувати Reolink RTSP. Увімкніть HTTP у налаштуваннях прошивки камери та перезапустіть майстер.",
+ "reolink-http": "Для кращої сумісності HTTP-потоки Reolink повинні використовувати FFmpeg. Увімкніть для цього потоку опцію «Використовувати режим сумісності потоків»."
+ },
+ "dahua": {
+ "substreamWarning": "Підпотік 1 заперечений до низького розділу. Багато камери Dahua / Amcrest / EmpireTech підтримують додаткові підтоки, які потрібно включити в налаштуваннях камери. Рекомендується перевірити та використовувати ці потоки, якщо вони доступні."
+ },
+ "hikvision": {
+ "substreamWarning": "Підпотік 1 заперечений до низького розділу. Багато камер Hikvision підтримують додаткові підтоки, які повинні бути включені в налаштуваннях камери. Рекомендується перевірити та використовувати ці потоки, якщо вони доступні."
+ }
+ }
+ }
+ },
+ "cameraManagement": {
+ "title": "Керування камерами",
+ "addCamera": "Додати нову камеру",
+ "editCamera": "Редагувати камеру:",
+ "selectCamera": "Виберіть камеру",
+ "backToSettings": "Назад до налаштувань камери",
+ "streams": {
+ "title": "Увімкнути/вимкнути камери",
+ "desc": "Тимчасово вимкніть камеру до перезапуску Frigate. Вимкнення камери повністю зупиняє обробку потоків цієї камери в Frigate. Функції виявлення, запису та налагодження будуть недоступні.
Примітка: це не вимикає ретрансляції "
+ },
+ "cameraConfig": {
+ "add": "Додати камеру",
+ "edit": "Редагувати камеру",
+ "description": "Налаштуйте параметри камери, включаючи потокові входи та ролі.",
+ "name": "Назва камери",
+ "nameRequired": "Потрібно вказати назву камери",
+ "nameLength": "Назва камери має містити менше 64 символів.",
+ "namePlaceholder": "наприклад, передні_двері або огляд заднього двору",
+ "enabled": "Увімкнено",
+ "ffmpeg": {
+ "inputs": "Вхідні потоки",
+ "path": "Шлях потоку",
+ "pathRequired": "Шлях потоку обов'язковий",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Ролі",
+ "rolesRequired": "Потрібна хоча б одна роль",
+ "rolesUnique": "Кожна роль (аудіо, виявлення, запис) може бути призначена лише одному потоку",
+ "addInput": "Додати вхідний потік",
+ "removeInput": "Вилучити вхідний потік",
+ "inputsRequired": "Потрібен принаймні один вхідний потік"
+ },
+ "go2rtcStreams": "go2rtc Стріми",
+ "streamUrls": "URL-адреси потоків",
+ "addUrl": "Додати URL-адресу",
+ "addGo2rtcStream": "Додати потік go2rtc",
+ "toast": {
+ "success": "Камеру {{cameraName}} успішно збережено"
+ }
+ }
+ },
+ "cameraReview": {
+ "title": "Налаштування перегляду камери",
+ "object_descriptions": {
+ "title": "Генеративні описи об'єктів штучного інтелекту",
+ "desc": "Тимчасово ввімкнути/вимкнути генеративні описи об'єктів ШІ для цієї камери до перезавантаження Frigate. Якщо вимкнено, згенеровані ШІ описи не запитуватимуться для об'єктів, що відстежуються на цій камері."
+ },
+ "review_descriptions": {
+ "title": "Описи генеративного ШІ-огляду",
+ "desc": "Тимчасово ввімкнути/вимкнути генеративні описи огляду за допомогою штучного інтелекту для цієї камери до перезавантаження Frigate. Якщо вимкнено, згенеровані штучним інтелектом описи не запитуватимуться для елементів огляду на цій камері."
+ },
+ "review": {
+ "title": "Огляду",
+ "desc": "Тимчасово ввімкнути/вимкнути сповіщення та виявлення для цієї камери до перезавантаження Frigate. Якщо вимкнено, нові елементи огляду не створюватимуться. ",
+ "alerts": "Сповіщення ",
+ "detections": "Виявлення "
+ },
+ "reviewClassification": {
+ "title": "Класифікація оглядів",
+ "desc": "Frigate класифікує об'єкти перевірки як сповіщення та виявлення. За замовчуванням усі об'єкти людина та автомобіль вважаються сповіщеннями. Ви можете уточнити класифікацію об'єктів перевірки, налаштувавши для них необхідні зони.",
+ "noDefinedZones": "Для цієї камери не визначено жодної зони.",
+ "objectAlertsTips": "Усі об’єкти {{alertsLabels}} на {{cameraName}} будуть відображатися як сповіщення.",
+ "zoneObjectAlertsTips": "Усі об’єкти {{alertsLabels}}, виявлені в {{zone}} на {{cameraName}}, будуть відображатися як сповіщення.",
+ "objectDetectionsTips": "Усі об’єкти {{detectionsLabels}}, які не класифіковані на {{cameraName}}, будуть відображатися як виявлені, незалежно від того, в якій зоні вони знаходяться.",
+ "zoneObjectDetectionsTips": {
+ "text": "Усі об’єкти {{detectionsLabels}}, що не належать до категорії {{zone}} на {{cameraName}}, будуть відображатися як Виявлення.",
+ "notSelectDetections": "Усі об’єкти {{detectionsLabels}}, виявлені в {{zone}} на {{cameraName}}, які не віднесені до категорії «Сповіщення», будуть відображатися як Виявлення незалежно від того, в якій зоні вони знаходяться.",
+ "regardlessOfZoneObjectDetectionsTips": "Усі об’єкти {{detectionsLabels}}, які не класифіковані на {{cameraName}}, будуть відображатися як виявлені, незалежно від того, в якій зоні вони знаходяться."
+ },
+ "unsavedChanges": "Незбережені налаштування класифікації рецензій для {{camera}}",
+ "selectAlertsZones": "Виберіть зони для сповіщень",
+ "selectDetectionsZones": "Виберіть зони для виявлення",
+ "limitDetections": "Обмеження виявлення певними зонами",
+ "toast": {
+ "success": "Конфігурацію класифікації перегляду збережено. Перезапустіть Frigate, щоб застосувати зміни."
+ }
+ }
}
}
diff --git a/web/public/locales/uk/views/system.json b/web/public/locales/uk/views/system.json
index b1472f7a7..b65616c60 100644
--- a/web/public/locales/uk/views/system.json
+++ b/web/public/locales/uk/views/system.json
@@ -57,10 +57,20 @@
"text_embedding": "Вбудовування тексту",
"face_recognition": "Розпізнавання обличчя",
"yolov9_plate_detection_speed": "Швидкість виявлення номерних знаків YOLOv9",
- "yolov9_plate_detection": "Виявлення пластин YOLOv9"
+ "yolov9_plate_detection": "Виявлення пластин YOLOv9",
+ "review_description": "Опис огляду",
+ "review_description_speed": "Огляд Опис Швидкість",
+ "review_description_events_per_second": "Опис огляду",
+ "object_description": "Опис об'єкта",
+ "object_description_speed": "Опис об'єкта Швидкість",
+ "object_description_events_per_second": "Опис об'єкта",
+ "classification": "Класифікація {{name}}",
+ "classification_speed": "Швидкість класифікації {{name}}",
+ "classification_events_per_second": "{{name}} Подій класифікації за секунду"
},
"title": "Збагаченням",
- "infPerSecond": "Висновки за секунду"
+ "infPerSecond": "Висновки за секунду",
+ "averageInf": "Середній час висновування"
},
"general": {
"title": "Загальна",
@@ -95,19 +105,32 @@
"toast": {
"success": "Інформацію про графічний процесор скопійовано в буфер обміну"
}
+ },
+ "intelGpuWarning": {
+ "title": "Попередження щодо статистики графічного процесора Intel",
+ "message": "Статистика графічного процесора недоступна",
+ "description": "Це відома помилка в інструментах звітності статистики графічного процесора Intel (intel_gpu_top), яка неодноразово повертає використання графічного процесора на рівні 0%, навіть у випадках, коли апаратне прискорення та виявлення об'єктів працюють належним чином на (i)GPU. Це не помилка Frigate. Ви можете перезавантажити хост, щоб тимчасово виправити проблему та переконатися, що графічний процесор працює правильно. Це не впливає на продуктивність."
}
},
"otherProcesses": {
"processMemoryUsage": "Використання пам'яті процесу",
"processCpuUsage": "Використання процесора процесу",
- "title": "Інші процеси"
+ "title": "Інші процеси",
+ "series": {
+ "go2rtc": "go2rtc",
+ "recording": "запис",
+ "review_segment": "сегмент огляду",
+ "embeddings": "вбудовування",
+ "audio_detector": "аудіодетектор"
+ }
},
"detector": {
"temperature": "Температура детектора",
"title": "Детектори",
"inferenceSpeed": "Швидкість виведення детектора",
"cpuUsage": "Використання процесора детектора",
- "memoryUsage": "Використання пам'яті детектора"
+ "memoryUsage": "Використання пам'яті детектора",
+ "cpuUsageInformation": "Процесор, що використовується для підготовки вхідних та вихідних даних до/з моделей виявлення. Це значення не вимірює використання логічного висновку, навіть якщо використовується графічний процесор або прискорювач."
}
},
"storage": {
@@ -129,7 +152,12 @@
"tips": "Це значення відображає загальний обсяг пам’яті, що використовується записами в базі даних Frigate. Frigate не відстежує використання пам’яті для всіх файлів на вашому диску.",
"earliestRecording": "Найдавніший доступний запис:"
},
- "title": "Зберігання"
+ "title": "Зберігання",
+ "shm": {
+ "title": "Розподіл спільної пам'яті (SHM)",
+ "warning": "Поточний розмір SHM, що становить {{total}} МБ, замалий. Збільште його принаймні до {{min_shm}} МБ.",
+ "readTheDocumentation": "Прочитайте документацію"
+ }
},
"lastRefreshed": "Останнє оновлення: ",
"stats": {
@@ -139,12 +167,13 @@
"reindexingEmbeddings": "Переіндексація вбудовування (виконано {{processed}}%)",
"cameraIsOffline": "{{camera}} не в мережі",
"detectIsSlow": "{{detect}} повільний ({{speed}} мс)",
- "detectIsVerySlow": "{{detect}} дуже повільний ({{speed}} мс)"
+ "detectIsVerySlow": "{{detect}} дуже повільний ({{speed}} мс)",
+ "shmTooLow": "Розмір /dev/shm ({{total}} МБ) слід збільшити щонайменше до {{min}} МБ."
},
"documentTitle": {
"cameras": "Статистика камер - Фрегат",
"storage": "Статистика сховища - Фрегат",
- "general": "Загальна статистика - Frigate",
+ "general": "Основна Статус – Frigate",
"enrichments": "Статистика збагачені - Фрегат",
"logs": {
"frigate": "Фрегатні журнали - Фрегат",
diff --git a/web/public/locales/ur/common.json b/web/public/locales/ur/common.json
index dbf35b3b6..37ff068c5 100644
--- a/web/public/locales/ur/common.json
+++ b/web/public/locales/ur/common.json
@@ -34,5 +34,6 @@
"month_other": "{{time}} مہینے",
"hour_one": "{{time}} گھنٹہ",
"hour_other": "{{time}} گھنٹے"
- }
+ },
+ "readTheDocumentation": "دستاویز پڑھیں"
}
diff --git a/web/public/locales/ur/views/classificationModel.json b/web/public/locales/ur/views/classificationModel.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/ur/views/classificationModel.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/audio.json b/web/public/locales/uz/audio.json
new file mode 100644
index 000000000..ddd93cd74
--- /dev/null
+++ b/web/public/locales/uz/audio.json
@@ -0,0 +1,3 @@
+{
+ "speech": "So'zlashuv"
+}
diff --git a/web/public/locales/uz/common.json b/web/public/locales/uz/common.json
new file mode 100644
index 000000000..2601b3f26
--- /dev/null
+++ b/web/public/locales/uz/common.json
@@ -0,0 +1,5 @@
+{
+ "time": {
+ "untilForTime": "{{time}} vaqtgacha"
+ }
+}
diff --git a/web/public/locales/uz/components/auth.json b/web/public/locales/uz/components/auth.json
new file mode 100644
index 000000000..ee2f33179
--- /dev/null
+++ b/web/public/locales/uz/components/auth.json
@@ -0,0 +1,5 @@
+{
+ "form": {
+ "user": "Foydalanuvchi nomi"
+ }
+}
diff --git a/web/public/locales/uz/components/camera.json b/web/public/locales/uz/components/camera.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/components/camera.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/components/dialog.json b/web/public/locales/uz/components/dialog.json
new file mode 100644
index 000000000..680c3b0d6
--- /dev/null
+++ b/web/public/locales/uz/components/dialog.json
@@ -0,0 +1,5 @@
+{
+ "restart": {
+ "title": "Frigate dasturini qayta ishga tushirishga aminmisiz?"
+ }
+}
diff --git a/web/public/locales/uz/components/filter.json b/web/public/locales/uz/components/filter.json
new file mode 100644
index 000000000..33d5b023e
--- /dev/null
+++ b/web/public/locales/uz/components/filter.json
@@ -0,0 +1,3 @@
+{
+ "filter": "Filtr"
+}
diff --git a/web/public/locales/uz/components/icons.json b/web/public/locales/uz/components/icons.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/components/icons.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/components/input.json b/web/public/locales/uz/components/input.json
new file mode 100644
index 000000000..ed23647c5
--- /dev/null
+++ b/web/public/locales/uz/components/input.json
@@ -0,0 +1,7 @@
+{
+ "button": {
+ "downloadVideo": {
+ "label": "Videoni yuklab olish"
+ }
+ }
+}
diff --git a/web/public/locales/uz/components/player.json b/web/public/locales/uz/components/player.json
new file mode 100644
index 000000000..1e126a82b
--- /dev/null
+++ b/web/public/locales/uz/components/player.json
@@ -0,0 +1,3 @@
+{
+ "noRecordingsFoundForThisTime": "Ushbu vaqt uchun hech qanday qayd mavjud emas"
+}
diff --git a/web/public/locales/uz/objects.json b/web/public/locales/uz/objects.json
new file mode 100644
index 000000000..3a4a299dd
--- /dev/null
+++ b/web/public/locales/uz/objects.json
@@ -0,0 +1,3 @@
+{
+ "person": "Shaxs"
+}
diff --git a/web/public/locales/uz/views/classificationModel.json b/web/public/locales/uz/views/classificationModel.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/classificationModel.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/views/configEditor.json b/web/public/locales/uz/views/configEditor.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/configEditor.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/views/events.json b/web/public/locales/uz/views/events.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/events.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/views/explore.json b/web/public/locales/uz/views/explore.json
new file mode 100644
index 000000000..f04d6847a
--- /dev/null
+++ b/web/public/locales/uz/views/explore.json
@@ -0,0 +1,3 @@
+{
+ "documentTitle": "Frigate dasturi bilan tanishish"
+}
diff --git a/web/public/locales/uz/views/exports.json b/web/public/locales/uz/views/exports.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/exports.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/views/faceLibrary.json b/web/public/locales/uz/views/faceLibrary.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/faceLibrary.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/views/live.json b/web/public/locales/uz/views/live.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/live.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/views/recording.json b/web/public/locales/uz/views/recording.json
new file mode 100644
index 000000000..33d5b023e
--- /dev/null
+++ b/web/public/locales/uz/views/recording.json
@@ -0,0 +1,3 @@
+{
+ "filter": "Filtr"
+}
diff --git a/web/public/locales/uz/views/search.json b/web/public/locales/uz/views/search.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/search.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/views/settings.json b/web/public/locales/uz/views/settings.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/settings.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/uz/views/system.json b/web/public/locales/uz/views/system.json
new file mode 100644
index 000000000..0967ef424
--- /dev/null
+++ b/web/public/locales/uz/views/system.json
@@ -0,0 +1 @@
+{}
diff --git a/web/public/locales/vi/common.json b/web/public/locales/vi/common.json
index af34c5ee3..dea1157d9 100644
--- a/web/public/locales/vi/common.json
+++ b/web/public/locales/vi/common.json
@@ -75,7 +75,10 @@
"formattedTimestampFilename": {
"12hour": "dd-MM-yy-h-mm-ss-a",
"24hour": "dd-MM-yy-HH-mm-s"
- }
+ },
+ "inProgress": "Đang tiến hành",
+ "invalidStartTime": "Thời gian bắt đầu không hợp lệ",
+ "invalidEndTime": "Thời gian kết thúc không hợp lệ"
},
"menu": {
"systemLogs": "Nhật ký hệ thống",
@@ -121,7 +124,15 @@
},
"yue": "粵語 (Tiếng Quảng Đông)",
"ca": "Català (Tiếng Catalan)",
- "th": "ไทย (Tiếng Thái)"
+ "th": "ไทย (Tiếng Thái)",
+ "ptBR": "Português brasileiro (Tiếng Bồ Đào Nha Brazil)",
+ "sr": "Српски (Tiếng Serbian)",
+ "sl": "Slovenščina (Tiếng Slovenian)",
+ "lt": "Lietuvių (Tiếng Lithuanian)",
+ "bg": "Български (Tiếng Bulgarian)",
+ "gl": "Galego (Tiếng Galician)",
+ "id": "Bahasa Indonesia (Tiếng Indonesian)",
+ "ur": "اردو (Tiếng Urdu)"
},
"system": "Hệ thống",
"systemMetrics": "Thông số hệ thống",
@@ -167,7 +178,8 @@
"explore": "Khám phá",
"export": "Xuất",
"uiPlayground": "UI Playground",
- "faceLibrary": "Thư viện khuôn mặt"
+ "faceLibrary": "Thư viện khuôn mặt",
+ "classification": "Phân loại"
},
"unit": {
"speed": {
@@ -177,10 +189,23 @@
"length": {
"meters": "mét (m)",
"feet": "feet (ft)"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/giờ",
+ "mbph": "MB/giờ",
+ "gbph": "GB/giờ"
}
},
"label": {
- "back": "Quay lại"
+ "back": "Quay lại",
+ "hide": "Ẩn {{item}}",
+ "show": "Hiển thị {{item}}",
+ "ID": "ID",
+ "none": "Không có",
+ "all": "Tất cả"
},
"button": {
"apply": "Áp dụng",
@@ -217,7 +242,8 @@
"export": "Xuất",
"deleteNow": "Xóa ngay",
"next": "Tiếp theo",
- "saving": "Đang lưu…"
+ "saving": "Đang lưu…",
+ "continue": "Tiếp tục"
},
"toast": {
"copyUrlToClipboard": "Đã sao chép liên kết.",
@@ -257,5 +283,18 @@
"title": "Không tìm thấy",
"desc": "Trang bạn đang tìm không tồn tại"
},
- "selectItem": "Chọn mục {{item}}"
+ "selectItem": "Chọn mục {{item}}",
+ "readTheDocumentation": "Đọc tài liệu",
+ "list": {
+ "two": "{{0}} và {{1}}",
+ "many": "{{items}}, và {{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "Không bắt buộc",
+ "internalID": "Internal ID Frigate sử dụng trong cấu hình và cơ sở dữ liệu"
+ },
+ "information": {
+ "pixels": "{{area}}px"
+ }
}
diff --git a/web/public/locales/vi/components/auth.json b/web/public/locales/vi/components/auth.json
index 3d942b9c2..bc664d59c 100644
--- a/web/public/locales/vi/components/auth.json
+++ b/web/public/locales/vi/components/auth.json
@@ -10,6 +10,7 @@
"loginFailed": "Đăng nhập không thành công",
"unknownError": "Lỗi không xác định. Kiểm tra nhật ký.",
"webUnknownError": "Lỗi không xác định. Kiểm tra nhật ký bảng điều khiển."
- }
+ },
+ "firstTimeLogin": "Lần đầu đăng nhập? Thông tin đăng nhập được in trong nhật ký (log) của Frigate."
}
}
diff --git a/web/public/locales/vi/components/camera.json b/web/public/locales/vi/components/camera.json
index 07617eb47..e67824e7b 100644
--- a/web/public/locales/vi/components/camera.json
+++ b/web/public/locales/vi/components/camera.json
@@ -49,7 +49,8 @@
"audioIsAvailable": "Âm thanh có sẵn cho luồng này",
"audioIsUnavailable": "Âm thanh không có sẵn cho luồng này",
"label": "Cài đặt trực tiếp Camera"
- }
+ },
+ "birdseye": "Toàn cảnh"
},
"name": {
"label": "Tên",
diff --git a/web/public/locales/vi/components/dialog.json b/web/public/locales/vi/components/dialog.json
index 53b1226b1..b8b2895ea 100644
--- a/web/public/locales/vi/components/dialog.json
+++ b/web/public/locales/vi/components/dialog.json
@@ -56,7 +56,8 @@
"noVaildTimeSelected": "Chưa chọn khoảng thời gian hợp lệ",
"failed": "Không thể bắt đầu xuất: {{error}}"
},
- "success": "Đã bắt đầu xuất thành công. Xem tệp trong thư mục /exports."
+ "success": "Đã bắt đầu xuất dữ liệu thành công. Xem tệp trên trang xuất dữ liệu.",
+ "view": "Xem"
},
"fromTimeline": {
"saveExport": "Lưu bản xuất",
@@ -92,7 +93,8 @@
"button": {
"deleteNow": "Xóa ngay",
"export": "Xuất",
- "markAsReviewed": "Đánh dấu là đã xem xét"
+ "markAsReviewed": "Đánh dấu là đã xem xét",
+ "markAsUnreviewed": "Đánh dấu là chưa xem xét"
}
},
"search": {
@@ -108,5 +110,13 @@
"placeholder": "Nhập tên cho tìm kiếm của bạn",
"overwrite": "{{searchName}} đã tồn tại. Lưu sẽ ghi đè lên giá trị hiện có."
}
+ },
+ "imagePicker": {
+ "selectImage": "Chọn hình thu nhỏ của đối tượng cần theo dõi",
+ "search": {
+ "placeholder": "Tìm theo nhãn hoặc nhãn phụ..."
+ },
+ "noImages": "Không tìm thấy hình thu nhỏ cho camera này",
+ "unknownLabel": "Ảnh kích hoạt đã lưu"
}
}
diff --git a/web/public/locales/vi/components/filter.json b/web/public/locales/vi/components/filter.json
index 1570067ab..3678ba1ab 100644
--- a/web/public/locales/vi/components/filter.json
+++ b/web/public/locales/vi/components/filter.json
@@ -93,7 +93,9 @@
"loadFailed": "Không thể tải biển số xe được nhận dạng.",
"loading": "Đang tải biển số xe được nhận dạng…",
"placeholder": "Nhập để tìm kiếm biển số xe…",
- "noLicensePlatesFound": "Không tìm thấy biển số xe nào."
+ "noLicensePlatesFound": "Không tìm thấy biển số xe nào.",
+ "selectAll": "Chọn tất cả",
+ "clearAll": "Xóa tất cả"
},
"more": "Thêm Bộ lọc",
"reset": {
@@ -122,5 +124,13 @@
"title": "Tất cả Khu vực",
"short": "Khu vực"
}
+ },
+ "classes": {
+ "label": "Các nhãn nhận diện",
+ "all": {
+ "title": "Tất cả nhãn nhận diện"
+ },
+ "count_one": "{{count}} Nhãn nhận diện",
+ "count_other": "{{count}} Các nhãn nhận diện"
}
}
diff --git a/web/public/locales/vi/views/classificationModel.json b/web/public/locales/vi/views/classificationModel.json
new file mode 100644
index 000000000..5db2c5960
--- /dev/null
+++ b/web/public/locales/vi/views/classificationModel.json
@@ -0,0 +1,59 @@
+{
+ "documentTitle": "شمار بندی کے ماڈل",
+ "button": {
+ "deleteClassificationAttempts": "Xóa Hình Ảnh Phân Loại",
+ "renameCategory": "Đổi Tên Lớp",
+ "deleteCategory": "Xoá Lớp",
+ "deleteImages": "Xoá Hình Ảnh",
+ "trainModel": "Huấn Luyện Mô Hình",
+ "addClassification": "Thêm Phân Loại",
+ "deleteModels": "Xoá Mô Hình",
+ "editModel": "Chỉnh sửa mô hình"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "Lớp Đã Bị Xoá",
+ "deletedImage": "Hình ảnh đã bị xóa",
+ "deletedModel_other": "Đã xóa thành công {{count}} mô hình",
+ "categorizedImage": "Phân Loại Hình Ảnh Thành Công",
+ "trainedModel": "Đã huấn luyện mô hình thành công.",
+ "trainingModel": "Đã bắt đầu huấn luyện mô hình thành công.",
+ "updatedModel": "Đã cập nhật cấu hình mô hình thành công",
+ "renamedCategory": "Đã đổi tên lớp thành công thành {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "Xóa không thành công: {{errorMessage}}",
+ "deleteCategoryFailed": "Xóa lớp không thành công: {{errorMessage}}",
+ "deleteModelFailed": "Xóa mô hình không thành công: {{errorMessage}}",
+ "categorizeFailed": "Phân loại hình ảnh không thành công: {{errorMessage}}",
+ "trainingFailed": "Huấn luyện mô hình thất bại. Vui lòng kiểm tra nhật ký của Frigate để biết chi tiết.",
+ "trainingFailedToStart": "Khởi động huấn luyện mô hình không thành công: {{errorMessage}}",
+ "updateModelFailed": "Cập nhật mô hình không thành công: {{errorMessage}}",
+ "renameCategoryFailed": "Không đổi tên được lớp: {{errorMessage}}"
+ }
+ },
+ "details": {
+ "scoreInfo": "Điểm số cho biết mức độ tự tin trung bình mà hệ thống xác định được cho tất cả các lần phát hiện đối tượng này."
+ },
+ "tooltip": {
+ "trainingInProgress": "Mô hình hiện đang được huấn luyện",
+ "noNewImages": "Không có hình ảnh mới để đào tạo. Trước tiên, hãy phân loại nhiều hình ảnh hơn trong tập dữ liệu.",
+ "noChanges": "Không có thay đổi nào đối với tập dữ liệu kể từ lần đào tạo cuối cùng.",
+ "modelNotReady": "Mô hình chưa sẵn sàng để huấn luyện"
+ },
+ "deleteCategory": {
+ "title": "Xóa lớp",
+ "desc": "Bạn có chắc chắn muốn xóa lớp {{name}} không? Điều này sẽ xóa vĩnh viễn tất cả các hình ảnh liên quan và yêu cầu đào tạo lại mô hình.",
+ "minClassesTitle": "Không thể xóa lớp",
+ "minClassesDesc": "Một mô hình phân loại phải có ít nhất 2 lớp. Thêm một lớp khác trước khi xóa lớp này."
+ },
+ "deleteModel": {
+ "title": "Xóa mô hình phân loại",
+ "single": "Bạn có chắc chắn muốn xóa {{name}} không? Thao tác này sẽ xóa vĩnh viễn tất cả dữ liệu liên quan bao gồm hình ảnh và dữ liệu đào tạo. Không thể hoàn tác hành động này.",
+ "desc_other": "Bạn có chắc chắn muốn xóa mô hình {{count}} không? Thao tác này sẽ xóa vĩnh viễn tất cả dữ liệu liên quan bao gồm hình ảnh và dữ liệu đào tạo. Không thể hoàn tác hành động này."
+ },
+ "edit": {
+ "title": "Chỉnh sửa mô hình phân loại",
+ "descriptionState": "Chỉnh sửa các lớp cho mô hình phân loại trạng thái này. Những thay đổi sẽ yêu cầu đào tạo lại mô hình."
+ }
+}
diff --git a/web/public/locales/vi/views/configEditor.json b/web/public/locales/vi/views/configEditor.json
index a9a0c4f82..a2ffce4a9 100644
--- a/web/public/locales/vi/views/configEditor.json
+++ b/web/public/locales/vi/views/configEditor.json
@@ -12,5 +12,7 @@
}
},
"configEditor": "Trình chỉnh sửa cấu hình",
- "documentTitle": "Trình chỉnh sửa - Frigate"
+ "documentTitle": "Trình chỉnh sửa - Frigate",
+ "safeConfigEditor": "Chỉnh sửa cấu hình (Chế độ an toàn)",
+ "safeModeDescription": "Frigate đang ở chế độ an toàn do lỗi kiểm tra cấu hình."
}
diff --git a/web/public/locales/vi/views/events.json b/web/public/locales/vi/views/events.json
index 4259ab2cc..94b2bc710 100644
--- a/web/public/locales/vi/views/events.json
+++ b/web/public/locales/vi/views/events.json
@@ -34,5 +34,29 @@
"button": "Các mục mới cần xem xét"
},
"markAsReviewed": "Đánh dấu là đã xem xét",
- "markTheseItemsAsReviewed": "Đánh dấu các mục này là đã xem xét"
+ "markTheseItemsAsReviewed": "Đánh dấu các mục này là đã xem xét",
+ "suspiciousActivity": "Hoạt động đáng ngờ",
+ "threateningActivity": "Hoạt động đe dọa",
+ "zoomIn": "Phóng To",
+ "zoomOut": "Thu nhỏ",
+ "detail": {
+ "label": "Chi tiết",
+ "noDataFound": "Không có dữ liệu chi tiết để xem xét",
+ "aria": "Chuyển đổi chế độ xem chi tiết",
+ "trackedObject_one": "{{count}} đối tượng",
+ "trackedObject_other": "{{count}} đối tượng",
+ "noObjectDetailData": "Không có dữ liệu chi tiết đối tượng nào khả dụng.",
+ "settings": "Cài đặt chế độ xem chi tiết",
+ "alwaysExpandActive": {
+ "title": "Luôn mở rộng mục đang hoạt động",
+ "desc": "Luôn mở rộng chi tiết đối tượng của mục đánh giá đang hoạt động khi có sẵn."
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "Điểm theo dõi",
+ "clickToSeek": "Nhấn để tua đến thời điểm này"
+ },
+ "normalActivity": "Bình thường",
+ "needsReview": "Cần xem xét",
+ "securityConcern": "Mối lo ngại về an ninh"
}
diff --git a/web/public/locales/vi/views/explore.json b/web/public/locales/vi/views/explore.json
index 99e4a65d5..7110009ce 100644
--- a/web/public/locales/vi/views/explore.json
+++ b/web/public/locales/vi/views/explore.json
@@ -60,12 +60,14 @@
"error": {
"updatedSublabelFailed": "Không thể cập nhật nhãn phụ: {{errorMessage}}",
"updatedLPRFailed": "Không thể cập nhật biển số xe: {{errorMessage}}",
- "regenerate": "Không thể gọi {{provider}} để lấy mô tả mới: {{errorMessage}}"
+ "regenerate": "Không thể gọi {{provider}} để lấy mô tả mới: {{errorMessage}}",
+ "audioTranscription": "Không thể yêu cầu phiên âm: {{errorMessage}}"
},
"success": {
"regenerate": "Một mô tả mới đã được yêu cầu từ {{provider}}. Tùy thuộc vào tốc độ của nhà cung cấp của bạn, mô tả mới có thể mất một chút thời gian để tạo lại.",
"updatedLPR": "Cập nhật biển số xe thành công.",
- "updatedSublabel": "Cập nhật nhãn phụ thành công."
+ "updatedSublabel": "Cập nhật nhãn phụ thành công.",
+ "audioTranscription": "Đã yêu cầu chuyển đổi âm thanh thành văn bản thành công. Tùy vào tốc độ của máy chủ Frigate, quá trình chuyển đổi có thể mất một khoảng thời gian để hoàn tất."
}
},
"tips": {
@@ -115,6 +117,9 @@
"title": "Chỉnh sửa biển số xe",
"desc": "Nhập một giá trị biển số xe mới cho {{label}} này",
"descNoLabel": "Nhập một giá trị biển số xe mới cho đối tượng được theo dõi này"
+ },
+ "score": {
+ "label": "Điểm tin cậy"
}
},
"itemMenu": {
@@ -144,6 +149,28 @@
},
"deleteTrackedObject": {
"label": "Xóa đối tượng được theo dõi này"
+ },
+ "addTrigger": {
+ "label": "Thêm sự kiện kích hoạt",
+ "aria": "Thêm trình kích hoạt cho đối tượng được theo dõi này"
+ },
+ "audioTranscription": {
+ "label": "Phiên âm",
+ "aria": "Yêu cầu phiên âm"
+ },
+ "downloadCleanSnapshot": {
+ "label": "Tải xuống ảnh chụp nhanh",
+ "aria": "Tải xuống ảnh chụp nhanh"
+ },
+ "viewTrackingDetails": {
+ "label": "Xem chi tiết theo dõi",
+ "aria": "Xem chi tiết theo dõi"
+ },
+ "showObjectDetails": {
+ "label": "Hiển thị đường dẫn đối tượng"
+ },
+ "hideObjectDetails": {
+ "label": "Ẩn đường dẫn đối tượng"
}
},
"exploreIsUnavailable": {
@@ -176,7 +203,7 @@
},
"dialog": {
"confirmDelete": {
- "desc": "Việc xóa đối tượng được theo dõi này sẽ xóa ảnh chụp nhanh, mọi dữ liệu nhúng đã lưu và mọi mục nhập vòng đời đối tượng liên quan. Đoạn ghi hình đã ghi của đối tượng được theo dõi này trong chế độ xem Lịch sử sẽ KHÔNG bị xóa.
Bạn có chắc chắn muốn tiếp tục không?",
+ "desc": "Việc xóa đối tượng được theo dõi này sẽ xóa ảnh chụp nhanh, mọi phần nhúng đã lưu và mọi mục nhập chi tiết theo dõi được liên kết. Đoạn phim đã ghi của đối tượng được theo dõi này trong chế độ xem Lịch sử sẽ KHÔNG bị xóa.
Bạn có chắc chắn muốn tiếp tục không?",
"title": "Xác nhận Xóa"
}
},
@@ -188,7 +215,9 @@
"error": "Không thể xóa đối tượng được theo dõi: {{errorMessage}}"
}
},
- "tooltip": "Khớp {{type}} ở mức {{confidence}}%"
+ "tooltip": "Khớp {{type}} ở mức {{confidence}}%",
+ "previousTrackedObject": "Đối tượng được theo dõi trước đó",
+ "nextTrackedObject": "Đối tượng được theo dõi tiếp theo"
},
"exploreMore": "Khám phá thêm các đối tượng {{label}}",
"trackedObjectDetails": "Chi tiết Đối tượng được theo dõi",
@@ -196,10 +225,67 @@
"details": "chi tiết",
"snapshot": "ảnh chụp nhanh",
"video": "video",
- "object_lifecycle": "vòng đời đối tượng"
+ "object_lifecycle": "vòng đời đối tượng",
+ "thumbnail": "Ảnh thu nhỏ",
+ "tracking_details": "chi tiết theo dõi"
},
"fetchingTrackedObjectsFailed": "Lỗi khi tìm nạp các đối tượng được theo dõi: {{errorMessage}}",
"documentTitle": "Khám phá - Frigate",
"generativeAI": "AI Tạo sinh",
- "trackedObjectsCount_other": "{{count}} đối tượng được theo dõi "
+ "trackedObjectsCount_other": "{{count}} đối tượng được theo dõi ",
+ "aiAnalysis": {
+ "title": "Phân tích bằng AI"
+ },
+ "concerns": {
+ "label": "Mối lo ngại"
+ },
+ "trackingDetails": {
+ "title": "Chi tiết theo dõi",
+ "noImageFound": "Không tìm thấy hình ảnh cho mốc thời gian này.",
+ "createObjectMask": "Tạo mặt nạ đối tượng",
+ "adjustAnnotationSettings": "Điều chỉnh cài đặt chú thích",
+ "scrollViewTips": "Nhấn để xem những khoảnh khắc quan trọng trong vòng đời của đối tượng này.",
+ "autoTrackingTips": "Vị trí khung bao sẽ không chính xác đối với các camera tự động theo dõi (autotracking).",
+ "count": "{{first}} của {{second}}",
+ "trackedPoint": "Điểm theo dõi",
+ "lifecycleItemDesc": {
+ "visible": "Đã phát hiện được {{label}}",
+ "entered_zone": "{{label}} đã vào {{zones}}",
+ "active": "{{label}} đã hoạt động",
+ "stationary": "{{label}} đã đứng yên",
+ "attribute": {
+ "faceOrLicense_plate": "Đã phát hiện {{attribute}} đối với {{label}}",
+ "other": "{{label}} được nhận diện là {{attribute}}"
+ },
+ "gone": "{{label}} đã rời đi",
+ "heard": "Đã nghe thấy {{label}}",
+ "external": "{{label}} đã được nhận diện",
+ "header": {
+ "zones": "Vùng",
+ "ratio": "Tỷ lệ",
+ "area": "Khu vực",
+ "score": "Điểm"
+ }
+ },
+ "annotationSettings": {
+ "title": "Cài đặt chú thích",
+ "showAllZones": {
+ "title": "Hiện tất cả các vùng",
+ "desc": "Luôn hiển thị các vùng trên khung hình khi có đối tượng đi vào vùng đó."
+ },
+ "offset": {
+ "label": "Độ lệch chú thích",
+ "desc": "Dữ liệu này lấy từ luồng phát hiện (detect feed) của camera bạn, nhưng được hiển thị chồng lên hình ảnh từ luồng ghi hình (record feed). Hai luồng này thường không đồng bộ hoàn hảo với nhau. Do đó, khung bao (bounding box) và đoạn video có thể không khớp chính xác. Bạn có thể sử dụng cài đặt này để điều chỉnh thời gian hiển thị chú thích (annotation) lùi hoặc tiến để đồng bộ tốt hơn với video đã ghi.",
+ "millisecondsToOffset": "Số mili giây để điều chỉnh thời gian hiển thị chú thích phát hiện. Mặc định: 0",
+ "tips": "Giảm giá trị nếu quá trình phát lại video ở phía trước các hộp và điểm đường dẫn, đồng thời tăng giá trị nếu quá trình phát lại video ở phía sau chúng. Giá trị này có thể âm.",
+ "toast": {
+ "success": "Độ lệch chú thích cho {{camera}} đã được lưu vào tệp cấu hình."
+ }
+ }
+ },
+ "carousel": {
+ "previous": "Trang trình bày trước",
+ "next": "Trang trình bày tiếp theo"
+ }
+ }
}
diff --git a/web/public/locales/vi/views/exports.json b/web/public/locales/vi/views/exports.json
index 6206f5821..95b3b87c6 100644
--- a/web/public/locales/vi/views/exports.json
+++ b/web/public/locales/vi/views/exports.json
@@ -13,5 +13,11 @@
"error": {
"renameExportFailed": "Đổi tên tệp xuất thất bại: {{errorMessage}}"
}
+ },
+ "tooltip": {
+ "shareExport": "Chia sẻ bản xuất",
+ "downloadVideo": "Tải video",
+ "editName": "Chỉnh sửa tên",
+ "deleteExport": "Xóa bản xuất"
}
}
diff --git a/web/public/locales/vi/views/faceLibrary.json b/web/public/locales/vi/views/faceLibrary.json
index e27adcf65..cef8b9da7 100644
--- a/web/public/locales/vi/views/faceLibrary.json
+++ b/web/public/locales/vi/views/faceLibrary.json
@@ -1,7 +1,7 @@
{
"selectItem": "Chọn mục {{item}}",
"description": {
- "addFace": "Hướng dẫn thêm bộ sưu tập mới vào Thư viện khuôn mặt.",
+ "addFace": "Thêm một bộ sưu tập mới vào Thư viện Khuôn Mặt bằng cách tải lên hình ảnh đầu tiên của bạn.",
"invalidName": "Tên không hợp lệ. Tên chỉ được phép chứa chữ cái, số, khoảng trắng, dấu nháy đơn, dấu gạch dưới và dấu gạch ngang.",
"placeholder": "Nhập tên cho bộ sưu tập này"
},
@@ -38,7 +38,7 @@
"success": {
"uploadedImage": "Tải lên hình ảnh thành công.",
"trainedFace": "Huấn luyện khuôn mặt thành công.",
- "updatedFaceScore": "Cập nhật điểm khuôn mặt thành công.",
+ "updatedFaceScore": "Đã cập nhật thành công điểm khuôn mặt thành {{name}} ({{score}}).",
"addFaceLibrary": "{{name}} đã được thêm thành công vào Thư viện Khuôn mặt!",
"deletedFace_other": "Đã xóa thành công {{count}} khuôn mặt.",
"deletedName_other": "{{count}} khuôn mặt đã được xóa thành công.",
@@ -76,15 +76,15 @@
"trainFace": "Huấn luyện khuôn mặt",
"nofaces": "Không có khuôn mặt nào",
"createFaceLibrary": {
- "nextSteps": "Để xây dựng một nền tảng vững chắc:Sử dụng tab Huấn luyện để chọn và huấn luyện trên hình ảnh cho mỗi người được phát hiện. Tập trung vào hình ảnh chụp thẳng để có kết quả tốt nhất; tránh huấn luyện các hình ảnh chụp khuôn mặt ở một góc. ",
+ "nextSteps": "Để xây dựng một nền tảng vững chắc:Sử dụng tab Nhận dạng gần đây để chọn và huấn luyện trên hình ảnh cho mỗi người được phát hiện. Tập trung vào hình ảnh chụp thẳng để có kết quả tốt nhất; tránh huấn luyện các hình ảnh chụp khuôn mặt ở một góc. ",
"title": "Tạo bộ sưu tập",
"desc": "Tạo một bộ sưu tập mới",
"new": "Tạo khuôn mặt mới"
},
"train": {
- "title": "Huấn luyện",
+ "title": "Nhận dạng gần đây",
"empty": "Không có nỗ lực nhận dạng khuôn mặt nào gần đây",
- "aria": "Chọn huấn luyện"
+ "aria": "Chọn các nhận dạng gần đây"
},
"selectFace": "Chọn khuôn mặt",
"pixels": "{{area}}px",
diff --git a/web/public/locales/vi/views/live.json b/web/public/locales/vi/views/live.json
index 3e8ab44f6..c238a34c6 100644
--- a/web/public/locales/vi/views/live.json
+++ b/web/public/locales/vi/views/live.json
@@ -29,6 +29,9 @@
"tips.documentation": "Đọc tài liệu ",
"available": "Đàm thoại hai chiều khả dụng cho luồng này",
"unavailable": "Đàm thoại hai chiều không khả dụng cho luồng này"
+ },
+ "debug": {
+ "picker": "Việc chọn luồng phát không khả dụng trong chế độ gỡ lỗi. Chế độ xem gỡ lỗi luôn sử dụng luồng được gán vai trò phát hiện (detect)."
}
},
"editLayout": {
@@ -71,7 +74,15 @@
"label": "Di chuyển camera PTZ sang phải"
}
},
- "presets": "Các thiết lập sẵn cho camera PTZ"
+ "presets": "Các thiết lập sẵn cho camera PTZ",
+ "focus": {
+ "in": {
+ "label": "Lấy nét gần (camera PTZ)"
+ },
+ "out": {
+ "label": "Lấy nét xa (camera PTZ)"
+ }
+ }
},
"manualRecording": {
"playInBackground": {
@@ -82,8 +93,8 @@
"failedToStart": "Không thể bắt đầu ghi hình theo yêu cầu.",
"started": "Đã bắt đầu ghi hình theo yêu cầu.",
"ended": "Đã kết thúc ghi hình theo yêu cầu.",
- "title": "Ghi hình theo yêu cầu",
- "tips": "Bắt đầu sự kiện ghi hình thủ công dựa trên cài đặt lưu trữ của camera này.",
+ "title": "Theo yêu cầu",
+ "tips": "Tải xuống ảnh chụp nhanh tức thì hoặc bắt đầu sự kiện thủ công dựa trên cài đặt lưu giữ bản ghi của máy ảnh này.",
"showStats": {
"label": "Hiện thống kê",
"desc": "Bật tùy chọn này để hiển thị thống kê luồng trên khung hình."
@@ -142,7 +153,8 @@
"recording": "Ghi hình",
"snapshots": "Ảnh chụp",
"audioDetection": "Phát hiện âm thanh",
- "autotracking": "Tự động theo dõi"
+ "autotracking": "Tự động theo dõi",
+ "transcription": "Phiên âm"
},
"history": {
"label": "Hiện cảnh quay lịch sử"
@@ -154,5 +166,24 @@
"active_objects": "Đối tượng hoạt động"
},
"notAllTips": "Cấu hình giữ lại ghi hình {{source}} của bạn được đặt là mode: {{effectiveRetainMode}}, vì vậy lần ghi hình theo yêu cầu này chỉ giữ lại các đoạn có {{effectiveRetainModeName}}."
+ },
+ "transcription": {
+ "enable": "Bật phiên âm trực tiếp",
+ "disable": "Tắt phiên âm trực tiếp"
+ },
+ "snapshot": {
+ "takeSnapshot": "Tải xuống ảnh chụp nhanh ngay lập tức",
+ "noVideoSource": "Không có nguồn video để chụp ảnh nhanh.",
+ "captureFailed": "Chụp ảnh nhanh không thành công.",
+ "downloadStarted": "Bắt đầu tải xuống ảnh chụp nhanh."
+ },
+ "noCameras": {
+ "title": "Không có camera nào được cấu hình",
+ "description": "Bắt đầu bằng cách kết nối một camera với Frigate.",
+ "buttonText": "Thêm Camera",
+ "restricted": {
+ "title": "Không có Camera nào khả dụng",
+ "description": "Bạn không có quyền xem bất kỳ camera nào trong nhóm này."
+ }
}
}
diff --git a/web/public/locales/vi/views/settings.json b/web/public/locales/vi/views/settings.json
index 4f0972425..69b37b837 100644
--- a/web/public/locales/vi/views/settings.json
+++ b/web/public/locales/vi/views/settings.json
@@ -7,9 +7,11 @@
"notifications": "Cài đặt Thông báo - Frigate",
"masksAndZones": "Trình chỉnh sửa Mặt nạ và Vùng - Frigate",
"object": "Gỡ lỗi - Frigate",
- "general": "Cài đặt Chung - Frigate",
+ "general": "Cài đặt giao diện – Frigate",
"frigatePlus": "Cài đặt Frigate+ - Frigate",
- "motionTuner": "Bộ tinh chỉnh Chuyển động - Frigate"
+ "motionTuner": "Bộ tinh chỉnh Chuyển động - Frigate",
+ "cameraManagement": "Quản Lý Camera - Frigate",
+ "cameraReview": "Cài Đặt Xem Lại Camera - Frigate"
},
"notification": {
"toast": {
@@ -77,7 +79,7 @@
},
"snapshotConfig": {
"table": {
- "camera": "Camera",
+ "camera": "Máy quay",
"cleanCopySnapshots": "Ảnh chụp nhanh clean_copy",
"snapshots": "Ảnh chụp nhanh"
},
@@ -142,6 +144,44 @@
"streams": {
"title": "Luồng phát",
"desc": "Tạm thời vô hiệu hóa một camera cho đến khi Frigate khởi động lại. Vô hiệu hóa một camera sẽ dừng hoàn toàn quá trình xử lý các luồng của camera này của Frigate. Việc phát hiện, ghi hình và gỡ lỗi sẽ không khả dụng.
Lưu ý: Điều này không vô hiệu hóa các luồng phát lại của go2rtc."
+ },
+ "object_descriptions": {
+ "title": "Mô tả đối tượng bằng AI tạo sinh",
+ "desc": "Tạm thời bật/tắt mô tả đối tượng bằng AI tạo sinh cho camera này. Khi tắt, mô tả do AI tạo sinh sẽ không được yêu cầu cho các đối tượng được theo dõi trên camera này."
+ },
+ "review_descriptions": {
+ "title": "Mô tả đánh giá bằng AI tạo sinh",
+ "desc": "Tạm thời bật/tắt mô tả xem lại bằng AI tạo sinh cho camera này. Khi tắt, mô tả do AI tạo sinh sẽ không được yêu cầu cho các mục xem lại trên camera này."
+ },
+ "addCamera": "Thêm Camera mới",
+ "editCamera": "Chỉnh sửa Camera:",
+ "selectCamera": "Chọn Camera",
+ "backToSettings": "Quay lại cài đặt Camera",
+ "cameraConfig": {
+ "add": "Thêm Camera",
+ "edit": "Chỉnh sửa Camera",
+ "description": "Cấu hình Camera, bao gồm luồng đầu vào và vai trò.",
+ "name": "Tên Camera",
+ "nameRequired": "Yêu cầu nhập tên Camera",
+ "nameInvalid": "Tên Camera chỉ được chứa chữ cái, số, dấu gạch dưới hoặc dấu gạch ngang",
+ "namePlaceholder": "Ví dụ: front_door",
+ "enabled": "Bật",
+ "ffmpeg": {
+ "inputs": "Luồng đầu vào",
+ "path": "Đường dẫn luồng",
+ "pathRequired": "Yêu cầu nhập đường dẫn luồng",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "Vai trò",
+ "rolesRequired": "Cần ít nhất một vai trò",
+ "rolesUnique": "Mỗi vai trò (âm thanh, phát hiện, ghi hình) chỉ có thể được gán cho một luồng duy nhất",
+ "addInput": "Thêm luồng đầu vào",
+ "removeInput": "Xóa luồng đầu vào",
+ "inputsRequired": "Cần ít nhất một luồng đầu vào"
+ },
+ "toast": {
+ "success": "Camera {{cameraName}} đã được lưu thành công"
+ },
+ "nameLength": "Tên của camera phải dưới 24 ký tự."
}
},
"masksAndZones": {
@@ -212,8 +252,8 @@
"point_other": "{{count}} điểm",
"toast": {
"success": {
- "noName": "Mặt nạ đối tượng đã được lưu. Khởi động lại Frigate để áp dụng các thay đổi.",
- "title": "{{polygonName}} đã được lưu. Khởi động lại Frigate để áp dụng các thay đổi."
+ "noName": "Mặt nạ đối tượng đã được lưu.",
+ "title": "{{polygonName}} đã được lưu."
}
},
"label": "Mặt nạ đối tượng",
@@ -256,11 +296,11 @@
"desc": "Danh sách các đối tượng áp dụng cho vùng này."
},
"toast": {
- "success": "Vùng ({{zoneName}}) đã được lưu. Khởi động lại Frigate để áp dụng các thay đổi."
+ "success": "Vùng ({{zoneName}}) đã được lưu."
},
"name": {
"inputPlaceHolder": "Nhập tên…",
- "tips": "Tên phải có ít nhất 2 ký tự và không được trùng với tên của camera hoặc một vùng khác.",
+ "tips": "Tên phải có ít nhất 2 ký tự, phải có ít nhất một chữ cái và không được là tên của camera hoặc vùng khác trên camera này.",
"title": "Tên"
},
"edit": "Chỉnh sửa Vùng",
@@ -293,8 +333,8 @@
"clickDrawPolygon": "Nhấp để vẽ một đa giác trên hình ảnh.",
"toast": {
"success": {
- "title": "{{polygonName}} đã được lưu. Khởi động lại Frigate để áp dụng các thay đổi.",
- "noName": "Mặt nạ chuyển động đã được lưu. Khởi động lại Frigate để áp dụng các thay đổi."
+ "title": "{{polygonName}} đã được lưu.",
+ "noName": "Mặt nạ chuyển động đã được lưu."
}
}
},
@@ -381,6 +421,19 @@
"desc": "Hiển thị các hộp xung quanh các khu vực phát hiện có chuyển động",
"tips": "Hộp chuyển động
Các hộp màu đỏ sẽ được chồng lên các khu vực của khung hình nơi chuyển động đang được phát hiện
",
"title": "Hộp chuyển động"
+ },
+ "paths": {
+ "title": "Đường dẫn",
+ "desc": "Hiển thị các điểm quan trọng trên đường đi của đối tượng được theo dõi",
+ "tips": "Đường đi
Đường thẳng và vòng tròn sẽ hiển thị các điểm quan trọng mà đối tượng được theo dõi đã di chuyển trong suốt quá trình theo dõi.
"
+ },
+ "openCameraWebUI": "Đang mở giao diện Web của {{camera}}",
+ "audio": {
+ "title": "Âm thanh",
+ "noAudioDetections": "Không phát hiện âm thanh",
+ "score": "điểm",
+ "currentRMS": "RMS hiện tại",
+ "currentdbFS": "dbFS hiện tại"
}
},
"users": {
@@ -519,7 +572,15 @@
"desc": "Theo mặc định, các cảnh báo gần đây trên bảng điều khiển Trực tiếp sẽ phát dưới dạng các video lặp lại nhỏ. Tắt tùy chọn này để chỉ hiển thị hình ảnh tĩnh của các cảnh báo gần đây trên thiết bị/trình duyệt này.",
"label": "Phát video cảnh báo"
},
- "title": "Bảng điều khiển trực tiếp"
+ "title": "Bảng điều khiển trực tiếp",
+ "displayCameraNames": {
+ "label": "Luôn hiển thị tên camera",
+ "desc": "Luôn hiển thị tên camera trong một con chip trong bảng điều khiển xem trực tiếp nhiều camera."
+ },
+ "liveFallbackTimeout": {
+ "label": "Hết thời gian chờ dự phòng của người chơi trực tiếp",
+ "desc": "Khi luồng trực tiếp chất lượng cao của camera không khả dụng, tự động chuyển sang chế độ băng thông thấp sau số giây này. Mặc định: 3."
+ }
},
"recordingsViewer": {
"defaultPlaybackRate": {
@@ -528,7 +589,7 @@
},
"title": "Trình xem Bản ghi"
},
- "title": "Cài đặt Chung"
+ "title": "Cài đặt giao diện"
},
"dialog": {
"unsavedChanges": {
@@ -607,10 +668,109 @@
"notifications": "Thông báo",
"motionTuner": "Tinh chỉnh Chuyển động",
"cameras": "Cài đặt Camera",
- "enrichments": "Làm giàu Dữ liệu"
+ "enrichments": "Làm giàu Dữ liệu",
+ "triggers": "Sự kiện kích hoạt",
+ "cameraManagement": "Quản lý",
+ "cameraReview": "Đánh giá",
+ "roles": "Vai trò"
},
"cameraSetting": {
- "camera": "Camera",
+ "camera": "Máy quay",
"noCamera": "Không có Camera"
+ },
+ "triggers": {
+ "documentTitle": "Sự kiện kích hoạt",
+ "management": {
+ "title": "Sự kiện kích hoạt",
+ "desc": "Quản lý sự kiện kích hoạt cho {{camera}}. Sử dụng kiểu \"ảnh xem trước\" để kích hoạt dựa trên ảnh xem trước tương tự cho đối tượng cần theo dõi đã chọn, và kiểu \"mô tả\" để kích hoạt dựa trên những mô tả tương tự cho đoạn văn bản bạn đã chỉ định."
+ },
+ "addTrigger": "Thêm sự kiện kích hoạt",
+ "table": {
+ "content": "Nội dung",
+ "threshold": "Ngưỡng",
+ "actions": "Hành động",
+ "noTriggers": "Không có sự kiện kích hoạt được cài đặt cho máy quay này.",
+ "type": "Kiểu",
+ "name": "Tên",
+ "deleteTrigger": "Xóa sự kiện kích hoạt",
+ "lastTriggered": "Lần kích hoạt gần nhất",
+ "edit": "Chỉnh sửa"
+ },
+ "type": {
+ "description": "Mô tả",
+ "thumbnail": "Ảnh xem trước"
+ },
+ "dialog": {
+ "form": {
+ "enabled": {
+ "description": "Kích hoạt hoặc vô hiệu hóa sự kiện kích hoạt này"
+ },
+ "actions": {
+ "title": "Các hành động",
+ "desc": "Theo mặc định, Frigate kích hoạt thông báo MQTT cho tất cả các trình kích hoạt. Nhãn phụ thêm tên kích hoạt vào nhãn đối tượng. Thuộc tính là siêu dữ liệu có thể tìm kiếm được lưu trữ riêng biệt trong siêu dữ liệu đối tượng được theo dõi.",
+ "error": {
+ "min": "Phải chọn ít nhất một hành động."
+ }
+ },
+ "name": {
+ "title": "Tên",
+ "placeholder": "Tên sự kiện kích hoạt",
+ "error": {
+ "minLength": "Trường phải dài ít nhất 2 ký tự.",
+ "invalidCharacters": "Trường chỉ có thể chứa các chữ cái, số, dấu gạch dưới và dấu gạch nối.",
+ "alreadyExists": "Một sự kiện kích hoạt trùng tên đã tồn tại cho máy quay này."
+ }
+ },
+ "type": {
+ "title": "Kiểu",
+ "placeholder": "Chọn kiểu cho sự kiện kích hoạt"
+ },
+ "content": {
+ "title": "Nội dung",
+ "imagePlaceholder": "Chọn một hình ảnh",
+ "textPlaceholder": "Nhập nội dung văn bản",
+ "imageDesc": "Chỉ 100 hình thu nhỏ gần đây nhất được hiển thị. Nếu bạn không thể tìm thấy hình thu nhỏ mong muốn, vui lòng xem lại các đối tượng trước đó trong Khám phá và thiết lập trình kích hoạt từ menu ở đó.",
+ "textDesc": "Nhập vẵn bản để kích hoạt hành động này khi một đối tượng theo dõi với mô tả tương tự được phát hiện.",
+ "error": {
+ "required": "Nội dung bắt buộc."
+ }
+ },
+ "threshold": {
+ "title": "Ngưỡng",
+ "error": {
+ "min": "Ngưỡng phải ít nhất bằng 0",
+ "max": "Ngưỡng lớn nhất phải bé hơn 1"
+ }
+ }
+ },
+ "createTrigger": {
+ "title": "Tạo sự kiện kích hoạt",
+ "desc": "Tạo sự kiện kích hoạt cho máy quay {{camera}}"
+ },
+ "editTrigger": {
+ "title": "Chỉnh sửa Sự kiện kích hoạt",
+ "desc": "Chỉnh sửa cài đặt cho sự kiện kích hoạt trên máy quay {{camera}}"
+ },
+ "deleteTrigger": {
+ "title": "Xóa Sự kiện kích hoạt",
+ "desc": "Bạn có chắc chắn muốn xóa sự kịn kích hoạt {{triggerName}}? Thao tác này không thể khôi phục được."
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "Sự kiện kích hoạt {{name}} đã được tạo thành công.",
+ "updateTrigger": "Sự kiện kích hoạt {{name}} đã được cập nhật thành công.",
+ "deleteTrigger": "Sự kiện kích hoạt {{name}} đã được xóa thành công."
+ },
+ "error": {
+ "createTriggerFailed": "Tạo sự kiện kích hoạt thất bại: {{errorMessage}}",
+ "updateTriggerFailed": "Cập nhật sự kiện kích hoạt thất bại: {{errorMessage}}",
+ "deleteTriggerFailed": "Xóa sự kiện kích hoạt thất bại: {{errorMessage}}"
+ }
+ },
+ "actions": {
+ "alert": "Gắn nhãn Cảnh báo",
+ "notification": "Gửi thông báo"
+ }
}
}
diff --git a/web/public/locales/vi/views/system.json b/web/public/locales/vi/views/system.json
index 31da0a086..bdaffe7b9 100644
--- a/web/public/locales/vi/views/system.json
+++ b/web/public/locales/vi/views/system.json
@@ -42,7 +42,12 @@
"gpuUsage": "Mức sử dụng GPU",
"gpuMemory": "Bộ nhớ GPU",
"gpuEncoder": "Bộ mã hóa GPU",
- "gpuDecoder": "Bộ giải mã GPU"
+ "gpuDecoder": "Bộ giải mã GPU",
+ "intelGpuWarning": {
+ "title": "Cảnh báo thống kê GPU Intel",
+ "message": "Không có số liệu thống kê GPU",
+ "description": "Đây là lỗi đã biết trong công cụ báo cáo thống kê GPU của Intel (intel_gpu_top), khi nó bị trục trặc và liên tục trả về mức sử dụng GPU là 0%, dù thực tế phần cứng tăng tốc và nhận diện đối tượng đang hoạt động đúng trên (i)GPU. Đây không phải lỗi của Frigate. Bạn có thể khởi động lại máy chủ để tạm thời khắc phục và xác nhận GPU vẫn hoạt động bình thường. Điều này không ảnh hưởng đến hiệu suất."
+ }
},
"otherProcesses": {
"processCpuUsage": "Mức sử dụng CPU của Tiến trình",
@@ -54,7 +59,8 @@
"memoryUsage": "Mức sử dụng Bộ nhớ của Bộ phát hiện",
"title": "Bộ phát hiện",
"inferenceSpeed": "Tốc độ Suy luận của Bộ phát hiện",
- "cpuUsage": "Mức sử dụng CPU của Bộ phát hiện"
+ "cpuUsage": "Mức sử dụng CPU của Bộ phát hiện",
+ "cpuUsageInformation": "Dùng CPU để chuẩn bị đầu vào và ngõ ra dữ liệu dùng cho mẫu nhận dạng. Giá trị này không đo lường mức sử dụng suy luận, ngay cả khi sử dụng GPU hoặc bộ tăng tốc."
},
"title": "Chung"
},
@@ -77,6 +83,10 @@
"title": "Bản ghi",
"tips": "Giá trị này thể hiện tổng dung lượng lưu trữ được sử dụng bởi các bản ghi trong cơ sở dữ liệu của Frigate. Frigate không theo dõi việc sử dụng dung lượng lưu trữ cho tất cả các tệp trên đĩa của bạn.",
"earliestRecording": "Bản ghi sớm nhất hiện có:"
+ },
+ "shm": {
+ "title": "Sắp xếp bộ nhớ được chia sẻ (SHM)",
+ "warning": "Bộ nhớ chia sẻ hiện tại quá thấp {{total}}MB. Tăng lên tối thiểu là {{min_shm}}MB."
}
},
"cameras": {
@@ -133,7 +143,8 @@
"ffmpegHighCpuUsage": "{{camera}} có mức sử dụng CPU FFmpeg cao ({{ffmpegAvg}}%)",
"detectHighCpuUsage": "{{camera}} có mức sử dụng CPU phát hiện cao ({{detectAvg}}%)",
"healthy": "Hệ thống đang hoạt động tốt",
- "reindexingEmbeddings": "Đang lập chỉ mục lại các embedding (hoàn thành {{processed}}%)"
+ "reindexingEmbeddings": "Đang lập chỉ mục lại các embedding (hoàn thành {{processed}}%)",
+ "shmTooLow": "/dev/shm ({{total}} MB) cần được tăng lên tối thiểu {{min}} MB."
},
"enrichments": {
"embeddings": {
@@ -147,10 +158,17 @@
"face_recognition_speed": "Tốc độ Nhận dạng Khuôn mặt",
"plate_recognition_speed": "Tốc độ Nhận dạng Biển số",
"yolov9_plate_detection_speed": "Tốc độ Phát hiện Biển số YOLOv9",
- "yolov9_plate_detection": "Phát hiện Biển số YOLOv9"
+ "yolov9_plate_detection": "Phát hiện Biển số YOLOv9",
+ "review_description": "Đánh giá mô tả",
+ "review_description_speed": "Đánh giá Mô tả Tốc độ",
+ "review_description_events_per_second": "Đánh giá mô tả",
+ "object_description": "Mô tả đối tượng",
+ "object_description_speed": "Đối tượng Mô tả Tốc độ",
+ "object_description_events_per_second": "Mô tả đối tượng"
},
"title": "Làm giàu Dữ liệu",
- "infPerSecond": "Suy luận Mỗi Giây"
+ "infPerSecond": "Suy luận Mỗi Giây",
+ "averageInf": "Thời gian suy luận trung bình"
},
"title": "Hệ thống",
"metrics": "Số liệu hệ thống",
diff --git a/web/public/locales/yue-Hant/common.json b/web/public/locales/yue-Hant/common.json
index 03f4f89b4..a65550366 100644
--- a/web/public/locales/yue-Hant/common.json
+++ b/web/public/locales/yue-Hant/common.json
@@ -76,6 +76,14 @@
"length": {
"feet": "呎",
"meters": "米"
+ },
+ "data": {
+ "kbps": "kB/秒",
+ "mbps": "MB/秒",
+ "gbps": "GB/秒",
+ "kbph": "kB/小時",
+ "mbph": "MB/小時",
+ "gbph": "GB/小時"
}
},
"label": {
@@ -160,7 +168,15 @@
"he": "עברית (希伯來文)",
"yue": "粵語 (廣東話)",
"th": "ไทย (泰文)",
- "ca": "Català (加泰羅尼亞語)"
+ "ca": "Català (加泰羅尼亞語)",
+ "ptBR": "Português brasileiro (巴西葡萄牙文)",
+ "sr": "Српски (塞爾維亞文)",
+ "sl": "Slovenščina (斯洛文尼亞文)",
+ "lt": "Lietuvių (立陶宛文)",
+ "bg": "Български (保加利亞文)",
+ "gl": "Galego (加利西亞文)",
+ "id": "Bahasa Indonesia (印尼文)",
+ "ur": "اردو (烏爾都文)"
},
"appearance": "外觀",
"darkMode": {
@@ -248,5 +264,9 @@
"documentTitle": "找不到頁面 - Frigate",
"desc": "找不到頁面",
"title": "404"
+ },
+ "readTheDocumentation": "閱讀文件",
+ "information": {
+ "pixels": "{{area}}像素"
}
}
diff --git a/web/public/locales/yue-Hant/components/camera.json b/web/public/locales/yue-Hant/components/camera.json
index 80cb5d833..ecfa4638c 100644
--- a/web/public/locales/yue-Hant/components/camera.json
+++ b/web/public/locales/yue-Hant/components/camera.json
@@ -40,7 +40,8 @@
"audioIsUnavailable": "此串流沒有音訊",
"placeholder": "選擇串流來源",
"stream": "串流"
- }
+ },
+ "birdseye": "鳥瞰"
},
"delete": {
"confirm": {
diff --git a/web/public/locales/yue-Hant/components/dialog.json b/web/public/locales/yue-Hant/components/dialog.json
index 775681b07..1a3911048 100644
--- a/web/public/locales/yue-Hant/components/dialog.json
+++ b/web/public/locales/yue-Hant/components/dialog.json
@@ -106,7 +106,15 @@
"button": {
"export": "匯出",
"markAsReviewed": "標記為已審查",
- "deleteNow": "立即刪除"
+ "deleteNow": "立即刪除",
+ "markAsUnreviewed": "標記為未審查"
}
+ },
+ "imagePicker": {
+ "selectImage": "選取追蹤物件縮圖",
+ "search": {
+ "placeholder": "以標籤或子標籤搜尋..."
+ },
+ "noImages": "未找到此鏡頭的縮圖"
}
}
diff --git a/web/public/locales/yue-Hant/components/filter.json b/web/public/locales/yue-Hant/components/filter.json
index b2de0f6e6..bfdc93576 100644
--- a/web/public/locales/yue-Hant/components/filter.json
+++ b/web/public/locales/yue-Hant/components/filter.json
@@ -91,7 +91,9 @@
"selectPlatesFromList": "從列表中選取一個或多個車牌。",
"placeholder": "輸入以搜尋車牌…",
"title": "已識別車牌",
- "loadFailed": "載入已識別車牌失敗。"
+ "loadFailed": "載入已識別車牌失敗。",
+ "selectAll": "全部選取",
+ "clearAll": "全部清除"
},
"estimatedSpeed": "預計速度({{unit}})",
"labels": {
@@ -122,5 +124,13 @@
"selectPreset": "選擇預設設定…"
},
"more": "更多篩選條件",
- "timeRange": "時間範圍"
+ "timeRange": "時間範圍",
+ "classes": {
+ "label": "分類",
+ "all": {
+ "title": "所有分類"
+ },
+ "count_one": "{{count}} 個分類",
+ "count_other": "{{count}} 個分類"
+ }
}
diff --git a/web/public/locales/yue-Hant/views/classificationModel.json b/web/public/locales/yue-Hant/views/classificationModel.json
new file mode 100644
index 000000000..0b72837bd
--- /dev/null
+++ b/web/public/locales/yue-Hant/views/classificationModel.json
@@ -0,0 +1,6 @@
+{
+ "documentTitle": "分類模型 - Frigate",
+ "details": {
+ "unknown": "未知"
+ }
+}
diff --git a/web/public/locales/yue-Hant/views/configEditor.json b/web/public/locales/yue-Hant/views/configEditor.json
index 3e23edb7f..5bf9d8a2e 100644
--- a/web/public/locales/yue-Hant/views/configEditor.json
+++ b/web/public/locales/yue-Hant/views/configEditor.json
@@ -12,5 +12,7 @@
"savingError": "儲存設定時出錯"
}
},
- "confirm": "是否不儲存就離開?"
+ "confirm": "是否不儲存就離開?",
+ "safeConfigEditor": "設定編輯器 (安全模式)",
+ "safeModeDescription": "Frigate 因配置驗證錯誤而進入安全模式。"
}
diff --git a/web/public/locales/yue-Hant/views/events.json b/web/public/locales/yue-Hant/views/events.json
index e9929a350..b5e9dc84d 100644
--- a/web/public/locales/yue-Hant/views/events.json
+++ b/web/public/locales/yue-Hant/views/events.json
@@ -34,5 +34,7 @@
},
"detections": "偵測",
"timeline.aria": "選擇時間線",
- "detected": "已偵測"
+ "detected": "已偵測",
+ "suspiciousActivity": "可疑行為",
+ "threateningActivity": "威脅行為"
}
diff --git a/web/public/locales/yue-Hant/views/explore.json b/web/public/locales/yue-Hant/views/explore.json
index 46db41b6f..e3a8c9409 100644
--- a/web/public/locales/yue-Hant/views/explore.json
+++ b/web/public/locales/yue-Hant/views/explore.json
@@ -101,12 +101,14 @@
"success": {
"updatedSublabel": "成功更新子標籤。",
"updatedLPR": "成功更新車牌號碼。",
- "regenerate": "已從 {{provider}} 請求新的描述。根據提供者的速度,生成新的描述可能需要一些時間。"
+ "regenerate": "已從 {{provider}} 請求新的描述。根據提供者的速度,生成新的描述可能需要一些時間。",
+ "audioTranscription": "成功請求音訊轉錄。"
},
"error": {
"regenerate": "呼叫 {{provider}} 以獲取新描述失敗:{{errorMessage}}",
"updatedSublabelFailed": "更新子標籤失敗:{{errorMessage}}",
- "updatedLPRFailed": "更新車牌號碼失敗:{{errorMessage}}"
+ "updatedLPRFailed": "更新車牌號碼失敗:{{errorMessage}}",
+ "audioTranscription": "請求音訊轉錄失敗:{{errorMessage}}"
}
}
},
@@ -152,7 +154,10 @@
"label": "快照分數"
},
"expandRegenerationMenu": "展開重新生成選單",
- "regenerateFromThumbnails": "從縮圖重新生成"
+ "regenerateFromThumbnails": "從縮圖重新生成",
+ "score": {
+ "label": "分數"
+ }
},
"itemMenu": {
"downloadVideo": {
@@ -181,6 +186,14 @@
},
"deleteTrackedObject": {
"label": "刪除此追蹤物件"
+ },
+ "addTrigger": {
+ "label": "新增觸發器",
+ "aria": "為此追蹤物件新增觸發器"
+ },
+ "audioTranscription": {
+ "label": "轉錄音訊",
+ "aria": "請求音訊轉錄"
}
},
"dialog": {
@@ -201,5 +214,11 @@
"tooltip": "已配對{{type}}({{confidence}}% 信心"
},
"trackedObjectsCount_other": "{{count}} 個追蹤物件 ",
- "exploreMore": "瀏覽更多{{label}}物件"
+ "exploreMore": "瀏覽更多{{label}}物件",
+ "aiAnalysis": {
+ "title": "AI 分析"
+ },
+ "concerns": {
+ "label": "關注"
+ }
}
diff --git a/web/public/locales/yue-Hant/views/faceLibrary.json b/web/public/locales/yue-Hant/views/faceLibrary.json
index 2c1e11b24..b215f66f2 100644
--- a/web/public/locales/yue-Hant/views/faceLibrary.json
+++ b/web/public/locales/yue-Hant/views/faceLibrary.json
@@ -11,7 +11,7 @@
"unknown": "未知"
},
"description": {
- "addFace": "逐步了解如何新增一個人臉庫的集合。",
+ "addFace": "上傳您的第一張圖片,即可在人臉庫中新增新的集合。",
"placeholder": "請輸入此集合的名稱",
"invalidName": "名稱無效。名稱只可以包含英文字母、數字、空格、撇號(')、底線(_)同連字號(-)。"
},
@@ -61,7 +61,7 @@
"selectImage": "請選擇一個圖片檔案。"
},
"dropActive": "將圖片拖到這裡…",
- "dropInstructions": "拖放圖片到此處,或點擊選取",
+ "dropInstructions": "拖放圖片或貼上到此處,或點擊選取",
"maxSize": "最大檔案大小:{{size}}MB"
},
"readTheDocs": "閱讀文件",
diff --git a/web/public/locales/yue-Hant/views/live.json b/web/public/locales/yue-Hant/views/live.json
index d9dda2630..bb3b440ee 100644
--- a/web/public/locales/yue-Hant/views/live.json
+++ b/web/public/locales/yue-Hant/views/live.json
@@ -37,6 +37,14 @@
"out": {
"label": "縮小 PTZ 鏡頭"
}
+ },
+ "focus": {
+ "in": {
+ "label": "PTZ 鏡頭拉近焦距"
+ },
+ "out": {
+ "label": "PTZ 鏡頭拉遠焦距"
+ }
}
},
"twoWayTalk": {
@@ -66,7 +74,7 @@
"disable": "隱藏串流統計資料"
},
"manualRecording": {
- "title": "按需錄影",
+ "title": "按需",
"tips": "根據此鏡頭的錄影保留設定手動啟動事件。",
"debugView": "除錯視圖",
"start": "開始按需錄影",
@@ -126,6 +134,9 @@
"playInBackground": {
"tips": "啟用此選項可在播放器隱藏時繼續串流播放。",
"label": "背景播放"
+ },
+ "debug": {
+ "picker": "除錯模式下無法選擇串流。除錯視圖永遠使用已分配偵測角色的串流。"
}
},
"cameraSettings": {
@@ -135,7 +146,8 @@
"snapshots": "快照",
"autotracking": "自動追蹤",
"audioDetection": "音訊偵測",
- "title": "{{camera}} 設定"
+ "title": "{{camera}} 設定",
+ "transcription": "音訊轉錄"
},
"history": {
"label": "顯示歷史影像"
@@ -154,5 +166,20 @@
"label": "編輯鏡頭群組"
},
"exitEdit": "結束編輯"
+ },
+ "transcription": {
+ "enable": "啟用即時音訊轉錄",
+ "disable": "停用即時音訊轉錄"
+ },
+ "noCameras": {
+ "title": "未設置任何鏡頭",
+ "description": "連接鏡頭開始使用。",
+ "buttonText": "新增鏡頭"
+ },
+ "snapshot": {
+ "takeSnapshot": "下載即時快照",
+ "noVideoSource": "無可用影片來源以擷取快照。",
+ "captureFailed": "擷取快照失敗。",
+ "downloadStarted": "已開始下載快照。"
}
}
diff --git a/web/public/locales/yue-Hant/views/settings.json b/web/public/locales/yue-Hant/views/settings.json
index a68c9d2bd..34982abb4 100644
--- a/web/public/locales/yue-Hant/views/settings.json
+++ b/web/public/locales/yue-Hant/views/settings.json
@@ -10,7 +10,9 @@
"general": "一般設定 - Frigate",
"frigatePlus": "Frigate+ 設定 - Frigate",
"notifications": "通知設定 - Frigate",
- "enrichments": "進階功能設定 - Frigate"
+ "enrichments": "進階功能設定 - Frigate",
+ "cameraManagement": "管理鏡頭 - Frigate",
+ "cameraReview": "鏡頭檢視設定 - Frigate"
},
"menu": {
"ui": "介面",
@@ -22,7 +24,11 @@
"users": "用戶",
"notifications": "通知",
"frigateplus": "Frigate+",
- "enrichments": "進階功能"
+ "enrichments": "進階功能",
+ "triggers": "觸發器",
+ "roles": "角色",
+ "cameraManagement": "管理",
+ "cameraReview": "審查"
},
"dialog": {
"unsavedChanges": {
@@ -178,6 +184,43 @@
"success": "審查分類設定已儲存。請重新啟動Frigate以套用更改。"
},
"unsavedChanges": "{{camera}}的審查分類設定尚未儲存"
+ },
+ "object_descriptions": {
+ "title": "生成式 AI 物件描述",
+ "desc": "暫時啟用或停用此鏡頭生成式 AI 物件描述。停用時,不會為此鏡頭的追蹤物件請求 AI 描述。"
+ },
+ "review_descriptions": {
+ "title": "生成式 AI 審查描述",
+ "desc": "暫時啟用或停用此鏡頭生成式 AI 審查描述。停用時,不會為此鏡頭的審查項目請求 AI 描述。"
+ },
+ "addCamera": "新增鏡頭",
+ "editCamera": "編輯鏡頭:",
+ "selectCamera": "選擇鏡頭",
+ "backToSettings": "返回鏡頭設定",
+ "cameraConfig": {
+ "add": "新增鏡頭",
+ "edit": "編輯鏡頭",
+ "description": "設定鏡頭,包括串流輸入同角色分配。",
+ "name": "鏡頭名稱",
+ "nameRequired": "必須填寫鏡頭名稱",
+ "nameLength": "鏡頭名稱不得多於 24 個字元。",
+ "namePlaceholder": "例如:front_door",
+ "enabled": "已啟用",
+ "ffmpeg": {
+ "inputs": "輸入串流",
+ "path": "串流路徑",
+ "pathRequired": "必須填寫串流路徑",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "角色",
+ "rolesRequired": "至少需要分配一個角色",
+ "rolesUnique": "每個角色(音訊、偵測、錄影)只可分配到一個串流",
+ "addInput": "新增輸入串流",
+ "removeInput": "移除輸入串流",
+ "inputsRequired": "至少需要一個輸入串流"
+ },
+ "toast": {
+ "success": "鏡頭 {{cameraName}} 已成功儲存"
+ }
}
},
"masksAndZones": {
@@ -417,6 +460,19 @@
"ratio": "比例",
"desc": "在圖片上畫矩形以查看面積與比例詳情",
"tips": "啟用此選項後,會於鏡頭畫面上繪製矩形,以顯示其面積及比例。這些數值可用於設定物件形狀過濾參數。"
+ },
+ "openCameraWebUI": "打開 {{camera}} 的網頁介面",
+ "audio": {
+ "title": "音訊",
+ "noAudioDetections": "未偵測到音訊",
+ "score": "分數",
+ "currentRMS": "目前 RMS",
+ "currentdbFS": "目前 dbFS"
+ },
+ "paths": {
+ "title": "軌跡",
+ "desc": "顯示追蹤物件軌跡上的重要點",
+ "tips": "軌跡
線條同圓圈會標示追蹤物件整個生命周期中移動過的重要點。
"
}
},
"users": {
@@ -502,7 +558,8 @@
"adminDesc": "可使用所有功能。",
"viewer": "觀看者",
"viewerDesc": "只限使用即時儀表板、審查、瀏覽及匯出功能。",
- "admin": "管理員"
+ "admin": "管理員",
+ "customDesc": "自訂角色,具特定鏡頭存取權限。"
},
"select": "選擇角色"
},
@@ -676,5 +733,386 @@
"success": "進階功能設定已儲存。請重新啟動 Frigate 以套用你的更改。",
"error": "儲存設定變更失敗:{{errorMessage}}"
}
+ },
+ "roles": {
+ "management": {
+ "title": "觀察者角色管理",
+ "desc": "管理自訂觀察者角色及其對此 Frigate 實例的鏡頭存取權限。"
+ },
+ "addRole": "新增角色",
+ "table": {
+ "role": "角色",
+ "cameras": "鏡頭",
+ "actions": "操作",
+ "noRoles": "未找到自訂角色。",
+ "editCameras": "編輯鏡頭",
+ "deleteRole": "刪除角色"
+ },
+ "toast": {
+ "success": {
+ "createRole": "角色 {{role}} 已成功建立",
+ "updateCameras": "角色 {{role}} 的鏡頭已更新",
+ "deleteRole": "角色 {{role}} 已成功刪除",
+ "userRolesUpdated_other": "{{count}} 位使用者被更新為「觀察者」角色,將可存取所有鏡頭。"
+ },
+ "error": {
+ "createRoleFailed": "建立角色失敗:{{errorMessage}}",
+ "updateCamerasFailed": "更新鏡頭失敗:{{errorMessage}}",
+ "deleteRoleFailed": "刪除角色失敗:{{errorMessage}}",
+ "userUpdateFailed": "更新使用者角色失敗:{{errorMessage}}"
+ }
+ },
+ "dialog": {
+ "createRole": {
+ "title": "建立新角色",
+ "desc": "新增角色,並指定鏡頭存取權限。"
+ },
+ "editCameras": {
+ "title": "編輯角色鏡頭",
+ "desc": "更新角色 {{role}} 的鏡頭存取權限。"
+ },
+ "deleteRole": {
+ "title": "刪除角色",
+ "desc": "此操作無法復原。將永久刪除該角色,並將使用此角色的所有使用者改為「觀察者」角色,可存取所有鏡頭。",
+ "warn": "你確定要刪除 {{role}} 嗎?",
+ "deleting": "正在刪除…"
+ },
+ "form": {
+ "role": {
+ "title": "角色名稱",
+ "placeholder": "輸入角色名稱",
+ "desc": "只允許字母、數字、句號或底線。",
+ "roleIsRequired": "必須填寫角色名稱",
+ "roleOnlyInclude": "角色名稱只可包含字母、數字、句號或底線",
+ "roleExists": "已有相同名稱的角色存在。"
+ },
+ "cameras": {
+ "title": "鏡頭",
+ "desc": "選擇此角色可存取的鏡頭。至少需要選擇一個鏡頭。",
+ "required": "至少需要選擇一個鏡頭。"
+ }
+ }
+ }
+ },
+ "triggers": {
+ "documentTitle": "觸發器",
+ "semanticSearch": {
+ "title": "語意搜尋已停用",
+ "desc": "必須啟用語意搜尋才能使用觸發器。"
+ },
+ "management": {
+ "title": "觸發器管理",
+ "desc": "管理 {{camera}} 的觸發器。使用縮圖類型可對與所選追蹤物件相似的縮圖觸發,使用描述類型可對與你指定文字描述相似的事件觸發。"
+ },
+ "addTrigger": "新增觸發器",
+ "table": {
+ "name": "名稱",
+ "type": "類型",
+ "content": "內容",
+ "threshold": "閾值",
+ "actions": "操作",
+ "noTriggers": "此鏡頭尚未設定任何觸發器。",
+ "edit": "編輯",
+ "deleteTrigger": "刪除觸發器",
+ "lastTriggered": "上次觸發"
+ },
+ "type": {
+ "thumbnail": "縮圖",
+ "description": "描述"
+ },
+ "actions": {
+ "alert": "標記為警報",
+ "notification": "發送通知"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "建立觸發器",
+ "desc": "為鏡頭 {{camera}} 建立觸發器"
+ },
+ "editTrigger": {
+ "title": "編輯觸發器",
+ "desc": "編輯鏡頭 {{camera}} 的觸發器設定"
+ },
+ "deleteTrigger": {
+ "title": "刪除觸發器",
+ "desc": "你確定要刪除觸發器 {{triggerName}} 嗎?此操作無法復原。"
+ },
+ "form": {
+ "name": {
+ "title": "名稱",
+ "placeholder": "輸入觸發器名稱",
+ "error": {
+ "minLength": "名稱至少需 2 個字元。",
+ "invalidCharacters": "名稱只可包含字母、數字、底線及連字符。",
+ "alreadyExists": "此鏡頭已有相同名稱的觸發器。"
+ }
+ },
+ "enabled": {
+ "description": "啟用或停用此觸發器"
+ },
+ "type": {
+ "title": "類型",
+ "placeholder": "選擇觸發器類型"
+ },
+ "friendly_name": {
+ "title": "顯示名稱",
+ "placeholder": "為此觸發器命名或描述",
+ "description": "此觸發器的可選顯示名稱或描述文字。"
+ },
+ "content": {
+ "title": "內容",
+ "imagePlaceholder": "選擇圖片",
+ "textPlaceholder": "輸入文字內容",
+ "imageDesc": "選擇圖片,當偵測到相似圖片時觸發此動作。",
+ "textDesc": "輸入文字,當偵測到相似追蹤物件描述時觸發此動作。",
+ "error": {
+ "required": "必須提供內容。"
+ }
+ },
+ "threshold": {
+ "title": "閾值",
+ "error": {
+ "min": "閾值至少為 0",
+ "max": "閾值最多為 1"
+ }
+ },
+ "actions": {
+ "title": "操作",
+ "desc": "預設情況下,Frigate 會對所有觸發器發送 MQTT 訊息。可選擇額外操作,在觸發器觸發時執行。",
+ "error": {
+ "min": "至少需要選擇一個操作。"
+ }
+ }
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "觸發器 {{name}} 已成功建立。",
+ "updateTrigger": "觸發器 {{name}} 已成功更新。",
+ "deleteTrigger": "觸發器 {{name}} 已成功刪除。"
+ },
+ "error": {
+ "createTriggerFailed": "建立觸發器失敗:{{errorMessage}}",
+ "updateTriggerFailed": "更新觸發器失敗:{{errorMessage}}",
+ "deleteTriggerFailed": "刪除觸發器失敗:{{errorMessage}}"
+ }
+ }
+ },
+ "cameraWizard": {
+ "title": "新增鏡頭",
+ "description": "請依照以下步驟,將新鏡頭加入 Frigate。",
+ "steps": {
+ "nameAndConnection": "名稱與連線",
+ "streamConfiguration": "串流設定",
+ "validationAndTesting": "驗證與測試"
+ },
+ "save": {
+ "success": "已成功儲存新鏡頭 {{cameraName}}。",
+ "failure": "儲存 {{cameraName}} 時發生錯誤。"
+ },
+ "testResultLabels": {
+ "resolution": "解析度",
+ "video": "影像",
+ "audio": "音訊",
+ "fps": "每秒影格數"
+ },
+ "commonErrors": {
+ "noUrl": "請輸入有效的串流網址",
+ "testFailed": "串流測試失敗:{{error}}"
+ },
+ "step1": {
+ "description": "輸入鏡頭詳細資料並測試連線。",
+ "cameraName": "鏡頭名稱",
+ "cameraNamePlaceholder": "例如:front_door 或 back_yard_overview",
+ "host": "主機名稱/IP 位址",
+ "port": "連接埠",
+ "username": "用戶名稱",
+ "usernamePlaceholder": "可選",
+ "password": "密碼",
+ "passwordPlaceholder": "選擇傳輸協定",
+ "selectTransport": "選擇傳輸協定",
+ "cameraBrand": "鏡頭品牌",
+ "selectBrand": "選擇鏡頭品牌以套用 URL 模板",
+ "customUrl": "自訂串流網址",
+ "brandInformation": "品牌資訊",
+ "brandUrlFormat": "適用於 RTSP 網址格式如下的鏡頭:{{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "testConnection": "測試連線",
+ "testSuccess": "連線測試成功!",
+ "testFailed": "連線測試失敗,請檢查輸入內容後再試一次。",
+ "streamDetails": "串流詳情",
+ "warnings": {
+ "noSnapshot": "無法從設定的串流中擷取快照。"
+ },
+ "errors": {
+ "brandOrCustomUrlRequired": "請選擇包含主機/IP 的鏡頭品牌,或選擇「其他」並輸入自訂網址",
+ "nameRequired": "必須輸入鏡頭名稱",
+ "nameLength": "鏡頭名稱長度不得超過 64 個字元",
+ "invalidCharacters": "鏡頭名稱包含無效字元",
+ "nameExists": "鏡頭名稱已存在",
+ "brands": {
+ "reolink-rtsp": "不建議使用 Reolink RTSP。建議在鏡頭設定中啟用 HTTP,並重新啟動鏡頭設定精靈。"
+ }
+ },
+ "docs": {
+ "reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras"
+ }
+ },
+ "step2": {
+ "description": "設定鏡頭的串流角色,並可新增額外串流。",
+ "streamsTitle": "鏡頭串流",
+ "addStream": "新增串流",
+ "addAnotherStream": "新增另一個串流",
+ "streamTitle": "串流 {{number}}",
+ "streamUrl": "串流網址",
+ "streamUrlPlaceholder": "rtsp://username:password@host:port/path",
+ "url": "網址",
+ "resolution": "解析度",
+ "selectResolution": "選擇解析度",
+ "quality": "畫質",
+ "selectQuality": "選擇畫質",
+ "roles": "角色",
+ "roleLabels": {
+ "detect": "物件偵測",
+ "record": "錄影",
+ "audio": "音訊"
+ },
+ "testStream": "測試連線",
+ "testSuccess": "串流測試成功!",
+ "testFailed": "串流測試失敗",
+ "testFailedTitle": "測試失敗",
+ "connected": "已連線",
+ "notConnected": "未連線",
+ "featuresTitle": "功能",
+ "go2rtc": "減少與鏡頭的連線數",
+ "detectRoleWarning": "至少需有一個串流設定為「偵測」角色才能繼續。",
+ "rolesPopover": {
+ "title": "串流角色",
+ "detect": "用於物件偵測的主要影像來源。",
+ "record": "根據設定儲存影片片段。",
+ "audio": "用於音訊偵測的來源。"
+ },
+ "featuresPopover": {
+ "title": "串流功能",
+ "description": "使用 go2rtc 轉串流以減少與鏡頭的直接連線。"
+ }
+ },
+ "step3": {
+ "description": "在儲存新鏡頭前進行最後驗證與分析。請先連線所有串流後再儲存。",
+ "validationTitle": "串流驗證",
+ "connectAllStreams": "連線所有串流",
+ "reconnectionSuccess": "重新連線成功。",
+ "reconnectionPartial": "部分串流重新連線失敗。",
+ "streamUnavailable": "無法預覽串流",
+ "reload": "重新載入",
+ "connecting": "正在連線...",
+ "streamTitle": "串流 {{number}}",
+ "valid": "有效",
+ "failed": "失敗",
+ "notTested": "未測試",
+ "connectStream": "連線",
+ "connectingStream": "連線中",
+ "disconnectStream": "中斷連線",
+ "estimatedBandwidth": "預計頻寬",
+ "roles": "角色",
+ "none": "無",
+ "error": "錯誤",
+ "streamValidated": "串流 {{number}} 驗證成功",
+ "streamValidationFailed": "串流 {{number}} 驗證失敗",
+ "saveAndApply": "儲存新鏡頭",
+ "saveError": "設定無效,請檢查你的設定。",
+ "issues": {
+ "title": "串流驗證",
+ "videoCodecGood": "影片編碼格式為 {{codec}}。",
+ "audioCodecGood": "音訊編碼格式為 {{codec}}。",
+ "noAudioWarning": "此串流未偵測到音訊,錄影將不會有聲音。",
+ "audioCodecRecordError": "錄影要支援音訊,必須使用 AAC 編碼。",
+ "audioCodecRequired": "要支援音訊偵測,必須有音訊串流。",
+ "restreamingWarning": "若減少錄影串流與鏡頭的連線,CPU 使用率可能會略微增加。",
+ "dahua": {
+ "substreamWarning": "子串流 1 被鎖定為低解析度。許多 Dahua / Amcrest / EmpireTech 鏡頭支援額外子串流,需要在鏡頭設定中啟用。建議如有可用,檢查並使用這些子串流。"
+ },
+ "hikvision": {
+ "substreamWarning": "子串流 1 被鎖定為低解析度。許多 Hikvision 鏡頭支援額外子串流,需要在鏡頭設定中啟用。建議如有可用,檢查並使用這些子串流。"
+ }
+ }
+ }
+ },
+ "cameraManagement": {
+ "title": "管理鏡頭",
+ "addCamera": "新增鏡頭",
+ "editCamera": "編輯鏡頭:",
+ "selectCamera": "選擇鏡頭",
+ "backToSettings": "返回鏡頭設定",
+ "streams": {
+ "title": "啟用/停用鏡頭",
+ "desc": "暫時停用鏡頭,直到 Frigate 重新啟動。停用鏡頭會完全停止 Frigate 對該鏡頭串流的處理。偵測、錄影及除錯功能將無法使用。
注意:這不會停用 go2rtc 轉串流。"
+ },
+ "cameraConfig": {
+ "add": "新增鏡頭",
+ "edit": "編輯鏡頭",
+ "description": "設定鏡頭,包括串流輸入與角色。",
+ "name": "鏡頭名稱",
+ "nameRequired": "必須輸入鏡頭名稱",
+ "nameLength": "鏡頭名稱長度不得超過 64 個字元。",
+ "namePlaceholder": "例如:front_door 或 back_yard_overview",
+ "enabled": "已啟用",
+ "ffmpeg": {
+ "inputs": "輸入串流",
+ "path": "串流路徑",
+ "pathRequired": "必須提供串流路徑",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "角色",
+ "rolesRequired": "至少需要一個角色",
+ "rolesUnique": "每個角色(音訊 / 偵測 / 錄影)只能分配給一個串流",
+ "addInput": "新增輸入串流",
+ "removeInput": "移除輸入串流",
+ "inputsRequired": "至少需要一個輸入串流"
+ },
+ "go2rtcStreams": "go2rtc 串流",
+ "streamUrls": "串流網址",
+ "addUrl": "新增網址",
+ "addGo2rtcStream": "新增 go2rtc 串流",
+ "toast": {
+ "success": "鏡頭 {{cameraName}} 已成功儲存"
+ }
+ }
+ },
+ "cameraReview": {
+ "title": "鏡頭檢視設定",
+ "object_descriptions": {
+ "title": "生成式 AI 物件描述",
+ "desc": "暫時啟用/停用此鏡頭的生成式 AI 物件描述。停用時,系統不會為此鏡頭的追蹤物件生成 AI 描述。"
+ },
+ "review_descriptions": {
+ "title": "生成式 AI 審查描述",
+ "desc": "暫時啟用/停用此鏡頭的生成式 AI 審查描述。停用時,系統不會為此鏡頭的審查項目生成 AI 描述。"
+ },
+ "review": {
+ "title": "審查",
+ "desc": "暫時啟用/停用此鏡頭的警報與偵測,直到 Frigate 重啟。停用時,不會產生新的審查項目。 ",
+ "alerts": "警報 ",
+ "detections": "偵測 "
+ },
+ "reviewClassification": {
+ "title": "審查分類",
+ "desc": "Frigate 將審查項目分類為警報與偵測。預設情況下,所有 person 與 car 物件會視為警報。你可以透過設定對應區域來精確分類審查項目。",
+ "noDefinedZones": "此鏡頭未定義任何區域。",
+ "objectAlertsTips": "在{{cameraName}}上所有{{alertsLabels}}物件將會顯示為警報。",
+ "zoneObjectAlertsTips": "在{{cameraName}}的{{zone}}區域偵測到的所有{{alertsLabels}}物件將會顯示為警報。",
+ "objectDetectionsTips": "無論位於哪個區域,在{{cameraName}}上所有未分類的{{detectionsLabels}}物件將會顯示為偵測結果。",
+ "zoneObjectDetectionsTips": {
+ "text": "在{{cameraName}}的{{zone}}區域內所有未分類的{{detectionsLabels}}物件將會顯示為偵測結果。",
+ "notSelectDetections": "無論位於哪個區域,在{{cameraName}}的{{zone}}區域偵測到、但未分類為警報的{{detectionsLabels}}物件將會顯示為偵測結果。",
+ "regardlessOfZoneObjectDetectionsTips": "無論位於哪個區域,在{{cameraName}}上所有未分類的{{detectionsLabels}}物件將會顯示為偵測結果。"
+ },
+ "unsavedChanges": "{{camera}}的審查分類設定尚未儲存",
+ "selectAlertsZones": "選擇警報的區域",
+ "selectDetectionsZones": "選擇偵測的區域",
+ "limitDetections": "限制偵測至特定區域",
+ "toast": {
+ "success": "審查分類設定已儲存。請重新啟動Frigate以套用更改。"
+ }
+ }
}
}
diff --git a/web/public/locales/yue-Hant/views/system.json b/web/public/locales/yue-Hant/views/system.json
index 8accc5bb1..6b52401c8 100644
--- a/web/public/locales/yue-Hant/views/system.json
+++ b/web/public/locales/yue-Hant/views/system.json
@@ -41,7 +41,8 @@
"memoryUsage": "偵測器記憶體使用量",
"title": "偵測器",
"cpuUsage": "偵測器 CPU 使用率",
- "temperature": "偵測器溫度"
+ "temperature": "偵測器溫度",
+ "cpuUsageInformation": "CPU 用於準備偵測模型的輸入同輸出數據。此數值不計算推理運算,即使使用 GPU 或加速器也是一樣。"
},
"hardwareInfo": {
"gpuUsage": "GPU 使用率",
@@ -102,6 +103,10 @@
},
"title": "鏡頭儲存",
"percentageOfTotalUsed": "佔總量百分比"
+ },
+ "shm": {
+ "title": "SHM(共享記憶體) 分配",
+ "warning": "目前 SHM 大小 {{total}}MB 太小,請增加至至少 {{min_shm}}MB。"
}
},
"cameras": {
@@ -158,7 +163,8 @@
"detectHighCpuUsage": "{{camera}} 的偵測 CPU 使用率過高 ({{detectAvg}}%)",
"healthy": "系統運作正常",
"ffmpegHighCpuUsage": "{{camera}} 的 FFmpeg CPU 使用率過高 ({{ffmpegAvg}}%)",
- "reindexingEmbeddings": "重新索引嵌入資料 (已完成 {{processed}}%)"
+ "reindexingEmbeddings": "重新索引嵌入資料 (已完成 {{processed}}%)",
+ "shmTooLow": "/dev/shm 分配({{total}} MB)太小,請增加至至少 {{min}} MB。"
},
"enrichments": {
"title": "進階功能",
diff --git a/web/public/locales/zh-CN/audio.json b/web/public/locales/zh-CN/audio.json
index bd97f632f..848418f84 100644
--- a/web/public/locales/zh-CN/audio.json
+++ b/web/public/locales/zh-CN/audio.json
@@ -102,7 +102,7 @@
"flapping_wings": "翅膀拍打",
"dogs": "狗群",
"rats": "老鼠",
- "mouse": "老鼠",
+ "mouse": "鼠标",
"patter": "啪嗒声",
"insect": "昆虫",
"cricket": "蟋蟀",
@@ -425,5 +425,79 @@
"television": "电视",
"radio": "收音机",
"field_recording": "实地录音",
- "scream": "尖叫"
+ "scream": "尖叫",
+ "sodeling": "索德铃",
+ "chird": "啾鸣",
+ "change_ringing": "变奏钟声",
+ "shofar": "羊角号",
+ "liquid": "液体",
+ "splash": "液体飞溅",
+ "slosh": "液体晃动",
+ "squish": "挤压",
+ "drip": "水滴声",
+ "pour": "倒水声",
+ "trickle": "细流水声",
+ "gush": "液体喷涌",
+ "fill": "注水声",
+ "spray": "喷洒",
+ "pump": "泵送",
+ "stir": "搅拌声",
+ "boiling": "沸腾声",
+ "sonar": "声呐声",
+ "arrow": "箭矢声",
+ "whoosh": "呼啸声",
+ "thump": "砰击声",
+ "thunk": "沉闷声",
+ "electronic_tuner": "电子调音器",
+ "effects_unit": "效果器",
+ "chorus_effect": "合唱效果",
+ "basketball_bounce": "篮球反弹声",
+ "bang": "砰声",
+ "slap": "拍击声",
+ "whack": "重击声",
+ "smash": "猛击声",
+ "breaking": "破碎声",
+ "bouncing": "弹跳声",
+ "whip": "鞭打声",
+ "flap": "扑动声",
+ "scratch": "刮擦声",
+ "scrape": "刮擦声",
+ "rub": "摩擦声",
+ "roll": "滚动声",
+ "crushing": "压碎声",
+ "crumpling": "揉皱声",
+ "tearing": "撕裂声",
+ "beep": "哔声",
+ "ping": "嘀声",
+ "ding": "叮声",
+ "clang": "铛声",
+ "squeal": "尖锐声",
+ "creak": "嘎吱声",
+ "rustle": "沙沙声",
+ "whir": "嗡声",
+ "clatter": "哐啷声",
+ "sizzle": "滋滋声",
+ "clicking": "点击声",
+ "clickety_clack": "咔嗒声",
+ "rumble": "隆隆声",
+ "plop": "扑通声",
+ "hum": "嗡鸣声",
+ "zing": "嗖声",
+ "boing": "嘣声",
+ "crunch": "咔嚓声",
+ "sine_wave": "正弦波声",
+ "harmonic": "谐波声",
+ "chirp_tone": "啾声",
+ "pulse": "脉冲",
+ "inside": "室内声",
+ "outside": "室外声",
+ "reverberation": "混响",
+ "echo": "回声",
+ "noise": "噪声",
+ "mains_hum": "电流嗡声",
+ "distortion": "失真声",
+ "sidetone": "旁音",
+ "cacophony": "刺耳噪声",
+ "throbbing": "脉动声",
+ "vibration": "振动声"
}
diff --git a/web/public/locales/zh-CN/common.json b/web/public/locales/zh-CN/common.json
index 1c253aee4..28fa8bd48 100644
--- a/web/public/locales/zh-CN/common.json
+++ b/web/public/locales/zh-CN/common.json
@@ -75,7 +75,11 @@
"formattedTimestampMonthDayYear": {
"12hour": "yy年MM月dd日",
"24hour": "yy年MM月dd日"
- }
+ },
+ "inProgress": "进行中",
+ "invalidStartTime": "无效的开始时间",
+ "invalidEndTime": "无效的结束时间",
+ "never": "从不"
},
"unit": {
"speed": {
@@ -85,10 +89,24 @@
"length": {
"feet": "英尺",
"meters": "米"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/每小时",
+ "mbph": "MB/每小时",
+ "gbph": "GB/每小时"
}
},
"label": {
- "back": "返回"
+ "back": "返回",
+ "hide": "隐藏 {{item}}",
+ "show": "显示 {{item}}",
+ "ID": "ID",
+ "none": "无",
+ "all": "所有",
+ "other": "其他"
},
"pagination": {
"label": "分页",
@@ -137,7 +155,8 @@
"deleteNow": "立即删除",
"next": "下一个",
"cameraAudio": "摄像头音频",
- "twoWayTalk": "双向对话"
+ "twoWayTalk": "双向对话",
+ "continue": "继续"
},
"menu": {
"system": "系统",
@@ -181,7 +200,16 @@
"cs": "捷克语 (Čeština)",
"yue": "粤语 (粵語)",
"th": "泰语(ไทย)",
- "ca": "加泰罗尼亚语 (Català )"
+ "ca": "加泰罗尼亚语 (Català )",
+ "ptBR": "巴西葡萄牙语 (Português brasileiro)",
+ "sr": "塞尔维亚语 (Српски)",
+ "sl": "斯洛文尼亚语 (Slovenščina)",
+ "lt": "立陶宛语 (Lietuvių)",
+ "bg": "保加利亚语 (Български)",
+ "gl": "加利西亚语 (Galego)",
+ "id": "印度尼西亚语 (Bahasa Indonesia)",
+ "ur": "乌尔都语 (اردو)",
+ "hr": "克罗地亚语(Hrvatski)"
},
"appearance": "外观",
"darkMode": {
@@ -229,7 +257,8 @@
"setPassword": "设置密码",
"title": "用户"
},
- "restart": "重启 Frigate"
+ "restart": "重启 Frigate",
+ "classification": "目标分类"
},
"toast": {
"copyUrlToClipboard": "已复制链接到剪贴板。",
@@ -257,5 +286,18 @@
"title": "404",
"desc": "页面未找到"
},
- "selectItem": "选择 {{item}}"
+ "selectItem": "选择 {{item}}",
+ "readTheDocumentation": "阅读文档",
+ "information": {
+ "pixels": "{{area}} 像素"
+ },
+ "list": {
+ "two": "{{0}} 和 {{1}}",
+ "many": "{{items}} 以及 {{last}}",
+ "separatorWithSpace": "、 "
+ },
+ "field": {
+ "optional": "可选",
+ "internalID": "Frigate 在配置与数据库中使用的内部 ID"
+ }
}
diff --git a/web/public/locales/zh-CN/components/auth.json b/web/public/locales/zh-CN/components/auth.json
index 015fa0ba8..dbfc34994 100644
--- a/web/public/locales/zh-CN/components/auth.json
+++ b/web/public/locales/zh-CN/components/auth.json
@@ -10,6 +10,7 @@
"loginFailed": "登录失败",
"unknownError": "未知错误,请检查日志。",
"webUnknownError": "未知错误,请检查控制台日志。"
- }
+ },
+ "firstTimeLogin": "首次尝试登录?请从 Frigate 日志中查找生成的登录密码等信息。"
}
}
diff --git a/web/public/locales/zh-CN/components/camera.json b/web/public/locales/zh-CN/components/camera.json
index fb1390d46..e01d5e9aa 100644
--- a/web/public/locales/zh-CN/components/camera.json
+++ b/web/public/locales/zh-CN/components/camera.json
@@ -32,7 +32,7 @@
"title": "{{cameraName}} 视频流设置",
"desc": "更改此摄像头组仪表板的实时视频流选项。这些设置特定于设备/浏览器。",
"audioIsAvailable": "此视频流支持音频",
- "audioIsUnavailable": "此视频流不支持音频",
+ "audioIsUnavailable": "此视频流不支持音频传输",
"audio": {
"tips": {
"title": "音频必须从您的摄像头输出并在 go2rtc 中配置此流。",
@@ -66,7 +66,8 @@
},
"stream": "视频流",
"placeholder": "选择视频流"
- }
+ },
+ "birdseye": "鸟瞰图"
}
},
"debug": {
@@ -80,7 +81,7 @@
"timestamp": "时间戳",
"zones": "区域",
"mask": "遮罩",
- "motion": "运动",
+ "motion": "画面变动",
"regions": "区域"
}
}
diff --git a/web/public/locales/zh-CN/components/dialog.json b/web/public/locales/zh-CN/components/dialog.json
index e7670d1e6..d84e125cf 100644
--- a/web/public/locales/zh-CN/components/dialog.json
+++ b/web/public/locales/zh-CN/components/dialog.json
@@ -12,7 +12,7 @@
"plus": {
"submitToPlus": {
"label": "提交至 Frigate+",
- "desc": "您希望避开的地点中的物体不应被视为误报。若将其作为误报提交,可能会导致AI模型容易混淆相关物体的识别。"
+ "desc": "你不希望检测指定地点中的目标或物体不应被视为误报。若将其作为误报提交,可能会导致 AI 模型容易混淆相关目标或物体的识别。"
},
"review": {
"true": {
@@ -28,9 +28,9 @@
},
"question": {
"label": "为 Frigate Plus 确认此标签",
- "ask_a": "这个对象是 {{label}} 吗?",
- "ask_an": "这个对象是 {{label}} 吗?",
- "ask_full": "这个对象是 {{untranslatedLabel}} ({{translatedLabel}}) 吗?"
+ "ask_a": "这个目标/物体是 {{label}} 吗?",
+ "ask_an": "这个目标/物体是 {{label}} 吗?",
+ "ask_full": "这个目标/物体是 {{untranslatedLabel}} ({{translatedLabel}}) 吗?"
}
}
},
@@ -59,12 +59,13 @@
"export": "导出",
"selectOrExport": "选择或导出",
"toast": {
- "success": "导出成功。进入 /exports 目录查看文件。",
+ "success": "导出成功。进入 导出 页面查看文件。",
"error": {
"failed": "导出失败:{{error}}",
"endTimeMustAfterStartTime": "结束时间必须在开始时间之后",
"noVaildTimeSelected": "未选择有效的时间范围"
- }
+ },
+ "view": "查看"
},
"fromTimeline": {
"saveExport": "保存导出",
@@ -114,7 +115,16 @@
"button": {
"export": "导出",
"markAsReviewed": "标记为已核查",
- "deleteNow": "立即删除"
+ "deleteNow": "立即删除",
+ "markAsUnreviewed": "标记为未核查"
}
+ },
+ "imagePicker": {
+ "selectImage": "选择追踪目标的缩略图",
+ "search": {
+ "placeholder": "通过标签或子标签搜索……"
+ },
+ "noImages": "未在此摄像头找到缩略图",
+ "unknownLabel": "已保存触发的图片"
}
}
diff --git a/web/public/locales/zh-CN/components/filter.json b/web/public/locales/zh-CN/components/filter.json
index 5824a421d..9bf90d291 100644
--- a/web/public/locales/zh-CN/components/filter.json
+++ b/web/public/locales/zh-CN/components/filter.json
@@ -41,15 +41,15 @@
"hasVideoClip": "包含视频片段",
"submittedToFrigatePlus": {
"label": "提交至 Frigate+",
- "tips": "你必须要先筛选具有快照的检测对象。
没有快照的跟踪对象无法提交至 Frigate+."
+ "tips": "你必须要先筛选有快照的追踪目标。
没有快照的追踪目标无法提交至 Frigate+。"
}
},
"sort": {
"label": "排序",
"dateAsc": "日期 (正序)",
"dateDesc": "日期 (倒序)",
- "scoreAsc": "对象分值 (正序)",
- "scoreDesc": "对象分值 (倒序)",
+ "scoreAsc": "目标分值 (正序)",
+ "scoreDesc": "目标分值 (倒序)",
"speedAsc": "预计速度 (正序)",
"speedDesc": "预计速度 (倒序)",
"relevance": "关联性"
@@ -65,14 +65,14 @@
"showReviewed": "显示已核查的项目"
},
"motion": {
- "showMotionOnly": "仅显示运动"
+ "showMotionOnly": "仅显示画面变动"
},
"explore": {
"settings": {
"title": "设置",
"defaultView": {
"title": "默认视图",
- "desc": "当未选择任何过滤器时,显示每个标签最近跟踪对象的摘要,或显示未过滤的网格。",
+ "desc": "当未选择任何筛选条件时,将显示每个标签下最近追踪目标的汇总信息,或者显示未筛选的网格视图。",
"summary": "摘要",
"unfilteredGrid": "未过滤网格"
},
@@ -82,7 +82,7 @@
},
"searchSource": {
"label": "搜索源",
- "desc": "选择是搜索缩略图还是跟踪对象的描述。",
+ "desc": "选择是搜索缩略图还是追踪目标的描述。",
"options": {
"thumbnailImage": "缩略图",
"description": "描述"
@@ -107,10 +107,10 @@
},
"trackedObjectDelete": {
"title": "确认删除",
- "desc": "删除这 {{objectLength}} 个跟踪对象将移除快照、任何已保存的嵌入和任何相关的对象生命周期条目。历史视图中这些跟踪对象的录制片段将不会被删除。
您确定要继续吗?
按住 Shift 键可在将来跳过此对话框。",
+ "desc": "删除这 {{objectLength}} 个已追踪目标将移除它们的快照、所有已保存的嵌入向量数据以及任何相关的目标全周期条目,但在 历史 页面中这些追踪目标的录制视频片段将不会被删除。
您确定要继续吗?
以后按住 Shift 键进行删除可跳过此提醒。",
"toast": {
- "success": "跟踪对象删除成功。",
- "error": "删除跟踪对象失败:{{errorMessage}}"
+ "success": "删除追踪目标成功。",
+ "error": "删除追踪目标失败:{{errorMessage}}"
}
},
"zoneMask": {
@@ -122,6 +122,20 @@
"loading": "正在加载识别的车牌…",
"placeholder": "输入以搜索车牌…",
"noLicensePlatesFound": "未找到车牌。",
- "selectPlatesFromList": "从列表中选择一个或多个车牌。"
+ "selectPlatesFromList": "从列表中选择一个或多个车牌。",
+ "selectAll": "选择所有",
+ "clearAll": "清除所有"
+ },
+ "classes": {
+ "label": "分类",
+ "all": {
+ "title": "所有分类"
+ },
+ "count_one": "{{count}} 个分类",
+ "count_other": "{{count}} 个分类"
+ },
+ "attributes": {
+ "label": "分类属性",
+ "all": "所有属性"
}
}
diff --git a/web/public/locales/zh-CN/components/player.json b/web/public/locales/zh-CN/components/player.json
index df6648048..0336c32a1 100644
--- a/web/public/locales/zh-CN/components/player.json
+++ b/web/public/locales/zh-CN/components/player.json
@@ -11,7 +11,7 @@
"title": "视频流离线",
"desc": "未在 {{cameraName}} 的 detect 流上接收到任何帧,请检查错误日志"
},
- "cameraDisabled": "摄像机已禁用",
+ "cameraDisabled": "摄像头已禁用",
"stats": {
"streamType": {
"title": "流类型:",
diff --git a/web/public/locales/zh-CN/objects.json b/web/public/locales/zh-CN/objects.json
index 161821a9d..193f87179 100644
--- a/web/public/locales/zh-CN/objects.json
+++ b/web/public/locales/zh-CN/objects.json
@@ -71,7 +71,7 @@
"door": "门",
"tv": "电视",
"laptop": "笔记本电脑",
- "mouse": "老鼠",
+ "mouse": "鼠标",
"remote": "遥控器",
"keyboard": "键盘",
"cell_phone": "手机",
diff --git a/web/public/locales/zh-CN/views/classificationModel.json b/web/public/locales/zh-CN/views/classificationModel.json
new file mode 100644
index 000000000..3e9cf67fe
--- /dev/null
+++ b/web/public/locales/zh-CN/views/classificationModel.json
@@ -0,0 +1,183 @@
+{
+ "documentTitle": "分类模型 - Frigate",
+ "button": {
+ "deleteClassificationAttempts": "删除分类图片",
+ "renameCategory": "重命名类别",
+ "deleteCategory": "删除类别",
+ "deleteImages": "删除图片",
+ "trainModel": "训练模型",
+ "addClassification": "添加分类",
+ "deleteModels": "删除模型",
+ "editModel": "编辑模型"
+ },
+ "toast": {
+ "success": {
+ "deletedCategory": "删除类别",
+ "deletedImage": "删除图片",
+ "categorizedImage": "成功分类图片",
+ "trainedModel": "训练模型成功。",
+ "trainingModel": "已开始训练模型。",
+ "deletedModel_other": "已删除 {{count}} 个模型",
+ "updatedModel": "已更新模型配置",
+ "renamedCategory": "成功修改类别名称为 {{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "删除失败:{{errorMessage}}",
+ "deleteCategoryFailed": "删除类别失败:{{errorMessage}}",
+ "categorizeFailed": "图片分类失败:{{errorMessage}}",
+ "trainingFailed": "训练模型失败,请查看 Frigate 日志获取详情。",
+ "deleteModelFailed": "删除模型失败:{{errorMessage}}",
+ "updateModelFailed": "更新模型失败:{{errorMessage}}",
+ "trainingFailedToStart": "开始训练模型失败:{{errorMessage}}",
+ "renameCategoryFailed": "修改类别名称失败:{{errorMessage}}"
+ }
+ },
+ "deleteCategory": {
+ "title": "删除类别",
+ "desc": "确定要删除类别 {{name}} 吗?此操作将永久删除所有关联的图片,并需要重新训练模型。",
+ "minClassesTitle": "无法删除此类别",
+ "minClassesDesc": "分类模型必须至少有2个类别。你需要先添加一个新的类别,然后再删除当前这个类别。"
+ },
+ "deleteDatasetImages": {
+ "title": "删除图片数据集",
+ "desc": "确定要从 {{dataset}} 中删除 {{count}} 张图片吗?此操作无法撤销,并将需要重新训练模型。"
+ },
+ "deleteTrainImages": {
+ "title": "删除训练的图片",
+ "desc": "确定要删除 {{count}} 张图片吗?此操作无法撤销。"
+ },
+ "renameCategory": {
+ "title": "重命名类别",
+ "desc": "请输入 {{name}} 的新名称。名称变更后需要重新训练模型。"
+ },
+ "description": {
+ "invalidName": "名称无效。名称只能包含字母、数字、空格、撇号、下划线和连字符。"
+ },
+ "train": {
+ "title": "最近分类记录",
+ "aria": "选择最近分类记录",
+ "titleShort": "近期"
+ },
+ "categories": "类别",
+ "createCategory": {
+ "new": "创建新类别"
+ },
+ "categorizeImageAs": "图片分类为:",
+ "categorizeImage": "图片分类",
+ "noModels": {
+ "object": {
+ "title": "未创建目标/物体分类模型",
+ "description": "创建自定义模型以分类检测到的目标。",
+ "buttonText": "创建目标/物体模型"
+ },
+ "state": {
+ "title": "尚未创建状态分类模型",
+ "description": "创建自定义模型以监控并分类摄像头特定区域的状态变化。",
+ "buttonText": "创建状态模型"
+ }
+ },
+ "wizard": {
+ "title": "创建新分类",
+ "steps": {
+ "nameAndDefine": "名称与定义",
+ "stateArea": "状态区域",
+ "chooseExamples": "选择范例"
+ },
+ "step1": {
+ "description": "状态模型用于监控摄像头固定区域的状态变化(例如门是否开启或关闭)。目标/物体模型用于为检测到的目标添加分类标签(例如区分宠物、快递员等)。",
+ "name": "名称",
+ "namePlaceholder": "请输入模型名称……",
+ "type": "类型",
+ "typeState": "状态",
+ "typeObject": "目标/物体",
+ "objectLabel": "目标/物体标签",
+ "objectLabelPlaceholder": "请选择目标类型……",
+ "classificationType": "分类方式",
+ "classificationTypeTip": "了解分类方式",
+ "classificationTypeDesc": "子标签会为目标标签添加附加文本(例如:“人员:美团”)。属性是可搜索的元数据,独立存储在目标的元信息中。",
+ "classificationSubLabel": "子标签",
+ "classificationAttribute": "属性",
+ "classes": "类别",
+ "classesTip": "了解类别",
+ "classesStateDesc": "定义摄像头区域内可能出现的不同状态。例如:车库门的“开启”和“关闭”。",
+ "classesObjectDesc": "定义用于分类检测目标的不同类别。例如:人员分类中的“快递员”、“居民”、“陌生人”。",
+ "classPlaceholder": "请输入分类名称……",
+ "errors": {
+ "nameRequired": "模型名称为必填项",
+ "nameLength": "模型名称长度不能超过 64 个字符",
+ "nameOnlyNumbers": "模型名称不能仅包含数字",
+ "classRequired": "至少需要一个类别",
+ "classesUnique": "类别名称必须唯一",
+ "stateRequiresTwoClasses": "状态模型至少需要两个类别",
+ "objectLabelRequired": "请选择一个目标标签",
+ "objectTypeRequired": "请选择一个目标标签",
+ "noneNotAllowed": "不能创建“none”(无标签)类别"
+ },
+ "states": "状态"
+ },
+ "step2": {
+ "description": "选择摄像头,并为摄像头定义要监控的区域。模型将对这些区域的状态进行分类。",
+ "cameras": "摄像头",
+ "selectCamera": "选择摄像头",
+ "noCameras": "点击 + 符号添加摄像头",
+ "selectCameraPrompt": "从列表中选择一个摄像头以定义其检测区域"
+ },
+ "step3": {
+ "selectImagesPrompt": "选择所有属于 {{className}} 的图片",
+ "selectImagesDescription": "点击图像进行选择,完成该类别后点击“继续”。",
+ "generating": {
+ "title": "正在生成样本图片",
+ "description": "Frigate 正在从录像中提取代表性图片。这可能需要一些时间……"
+ },
+ "training": {
+ "title": "正在训练模型",
+ "description": "系统正在后台训练模型。你可以关闭此对话框,训练完成后模型将自动开始运行。"
+ },
+ "retryGenerate": "重新生成",
+ "noImages": "未生成样本图像",
+ "classifying": "正在分类与训练……",
+ "trainingStarted": "已开始模型训练",
+ "errors": {
+ "noCameras": "未配置摄像头",
+ "noObjectLabel": "未选择目标标签",
+ "generateFailed": "示例生成失败:{{error}}",
+ "generationFailed": "生成失败,请重试。",
+ "classifyFailed": "图片分类失败:{{error}}"
+ },
+ "generateSuccess": "样本图片生成成功",
+ "allImagesRequired_other": "请对所有图片进行分类。还有 {{count}} 张图片需要分类。",
+ "modelCreated": "模型创建成功。请在“最近分类”页面为缺失的状态添加图片,然后训练模型。",
+ "missingStatesWarning": {
+ "title": "缺失状态示例",
+ "description": "建议为所有状态都选择示例图片以获得最佳效果。你也可以跳过当前为分类状态选择图片,但需要所有状态都有对应的图片,模型才能够进行训练。跳过后你可通过“最近分类”页面为缺失的状态分类添加图片,然后再训练模型。"
+ }
+ }
+ },
+ "deleteModel": {
+ "title": "删除分类模型",
+ "single": "你确定要删除 {{name}} 吗?此操作将永久删除所有相关数据,包括图片和训练数据,且无法撤销。",
+ "desc": "你确定要删除 {{count}} 个模型吗?此操作将永久删除所有相关数据,包括图片和训练数据,且无法撤销。"
+ },
+ "menu": {
+ "objects": "目标",
+ "states": "状态"
+ },
+ "details": {
+ "scoreInfo": "得分表示该目标所有检测结果的平均分类置信度。",
+ "none": "无分类",
+ "unknown": "未知"
+ },
+ "edit": {
+ "title": "编辑分类模型",
+ "descriptionState": "编辑此状态分类模型的类别;更改后需要重新训练模型。",
+ "descriptionObject": "编辑此目标分类模型的目标类型和分类类型。",
+ "stateClassesInfo": "注意:更改状态类别后需使用更新后的类别重新训练模型。"
+ },
+ "tooltip": {
+ "trainingInProgress": "模型正在训练中",
+ "noNewImages": "没有新的图片可用于训练。请先对数据集中的更多图片进行分类。",
+ "noChanges": "自上次训练以来,数据集未作任何更改。",
+ "modelNotReady": "模型尚未准备好进行训练"
+ },
+ "none": "无标签"
+}
diff --git a/web/public/locales/zh-CN/views/configEditor.json b/web/public/locales/zh-CN/views/configEditor.json
index 79e9b398c..a4ca5c5b7 100644
--- a/web/public/locales/zh-CN/views/configEditor.json
+++ b/web/public/locales/zh-CN/views/configEditor.json
@@ -12,5 +12,7 @@
"savingError": "保存配置时出错"
}
},
- "confirm": "是否退出并不保存?"
+ "confirm": "是否退出并不保存?",
+ "safeConfigEditor": "配置编辑器(安全模式)",
+ "safeModeDescription": "由于验证配置出现错误,Frigate目前为安全模式。"
}
diff --git a/web/public/locales/zh-CN/views/events.json b/web/public/locales/zh-CN/views/events.json
index 72a93104f..9c95ed1c4 100644
--- a/web/public/locales/zh-CN/views/events.json
+++ b/web/public/locales/zh-CN/views/events.json
@@ -2,14 +2,18 @@
"alerts": "警报",
"detections": "检测",
"motion": {
- "label": "运动",
- "only": "仅运动画面"
+ "label": "画面变动",
+ "only": "仅变动画面"
},
"allCameras": "所有摄像头",
"empty": {
"alert": "还没有“警报”类核查项",
"detection": "还没有“检测”类核查项",
- "motion": "还没有运动类数据"
+ "motion": "还没有画面变动类数据",
+ "recordingsDisabled": {
+ "title": "必须要开启录制功能",
+ "description": "必须要摄像头启用录制功能时,才可为其创建回放项目。"
+ }
},
"timeline": "时间线",
"timeline.aria": "选择时间线",
@@ -35,5 +39,30 @@
"selected": "已选择 {{count}} 个",
"selected_one": "已选择 {{count}} 个",
"selected_other": "已选择 {{count}} 个",
- "detected": "已检测"
+ "detected": "已检测",
+ "suspiciousActivity": "可疑活动",
+ "threateningActivity": "风险类活动",
+ "detail": {
+ "noDataFound": "没有可供核查的详细数据",
+ "aria": "切换详细视图",
+ "trackedObject_one": "{{count}}个目标或物体",
+ "trackedObject_other": "{{count}}个目标或物体",
+ "noObjectDetailData": "没有目标详细信息。",
+ "label": "详细信息",
+ "settings": "详细视图设置",
+ "alwaysExpandActive": {
+ "title": "始终展开当前项",
+ "desc": "在可用情况下,将始终展开当前核查项的目标详细信息。"
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "追踪点",
+ "clickToSeek": "点击从该时间进行寻找"
+ },
+ "zoomIn": "放大",
+ "zoomOut": "缩小",
+ "normalActivity": "正常",
+ "needsReview": "需要核查",
+ "securityConcern": "安全隐患",
+ "select_all": "所有"
}
diff --git a/web/public/locales/zh-CN/views/explore.json b/web/public/locales/zh-CN/views/explore.json
index 7db391e4d..8e66f2255 100644
--- a/web/public/locales/zh-CN/views/explore.json
+++ b/web/public/locales/zh-CN/views/explore.json
@@ -4,14 +4,14 @@
"exploreIsUnavailable": {
"title": "浏览功能不可用",
"embeddingsReindexing": {
- "context": "跟踪对象嵌入重新索引完成后,可以使用浏览功能。",
+ "context": "完成追踪目标嵌入重新索引后,才可以使用 浏览 功能。",
"startingUp": "启动中…",
"estimatedTime": "预计剩余时间:",
"finishingShortly": "即将完成",
"step": {
"thumbnailsEmbedded": "缩略图嵌入:",
"descriptionsEmbedded": "描述嵌入:",
- "trackedObjectsProcessed": "跟踪对象已处理:"
+ "trackedObjectsProcessed": "追踪目标已处理: "
}
},
"downloadingModels": {
@@ -23,25 +23,27 @@
"textTokenizer": "文本分词器"
},
"tips": {
- "context": "模型下载完成后,您可能需要重新索引跟踪对象的嵌入。",
+ "context": "模型下载完成后,您可能需要重新索引追踪目标的嵌入。",
"documentation": "阅读文档"
},
"error": "发生错误。请检查Frigate日志。"
}
},
- "trackedObjectDetails": "跟踪对象详情",
+ "trackedObjectDetails": "目标追踪详情",
"type": {
"details": "详情",
"snapshot": "快照",
"video": "视频",
- "object_lifecycle": "对象生命周期"
+ "object_lifecycle": "目标全周期",
+ "thumbnail": "缩略图",
+ "tracking_details": "追踪详情"
},
"objectLifecycle": {
- "title": "对象生命周期",
+ "title": "目标全周期",
"noImageFound": "未找到此时间戳的图像。",
- "createObjectMask": "创建对象遮罩",
+ "createObjectMask": "创建目标/物体遮罩",
"adjustAnnotationSettings": "调整标注设置",
- "scrollViewTips": "滚动查看此对象生命周期的重要时刻。",
+ "scrollViewTips": "滚动查看此目标全周期的关键节点。",
"autoTrackingTips": "自动跟踪摄像头的边界框位置可能不准确。",
"lifecycleItemDesc": {
"visible": "检测到 {{label}}",
@@ -65,7 +67,7 @@
"title": "标注设置",
"showAllZones": {
"title": "显示所有区域",
- "desc": "在对象进入区域的帧上始终显示区域。"
+ "desc": "始终在目标进入区域的帧上显示区域标记。"
},
"offset": {
"label": "标注偏移",
@@ -94,19 +96,23 @@
"viewInExplore": "在 浏览 中查看"
},
"tips": {
- "mismatch_other": "检测到 {{count}} 个不可用的对象,并已包含在此核查项中。这些对象可能未达到警报或检测标准,或者已被清理/删除。",
- "hasMissingObjects": "如果希望 Frigate 保存以下标签的跟踪对象,请调整您的配置:{{objects}}"
+ "mismatch_other": "检测到 {{count}} 个不可用的目标,并已包含在此核查项中。这些目标可能未达到警报或检测标准,或者已被清理/删除。",
+ "hasMissingObjects": "如果希望 Frigate 保存 {{objects}} 标签的追踪目标,请调整您的配置"
},
"toast": {
"success": {
"regenerate": "已向 {{provider}} 请求新的描述。根据提供商的速度,生成新描述可能需要一些时间。",
"updatedSublabel": "成功更新子标签。",
- "updatedLPR": "成功更新车牌。"
+ "updatedLPR": "成功更新车牌。",
+ "audioTranscription": "成功请求音频转录。根据你运行 Frigate 的服务器速度,转录可能需要一些时间才能完成。",
+ "updatedAttributes": "更新属性成功。"
},
"error": {
"regenerate": "调用 {{provider}} 生成新描述失败:{{errorMessage}}",
"updatedSublabelFailed": "更新子标签失败:{{errorMessage}}",
- "updatedLPRFailed": "更新车牌失败:{{errorMessage}}"
+ "updatedLPRFailed": "更新车牌失败:{{errorMessage}}",
+ "audioTranscription": "请求音频转录失败:{{errorMessage}}",
+ "updatedAttributesFailed": "更新属性失败:{{errorMessage}}"
}
}
},
@@ -114,14 +120,14 @@
"editSubLabel": {
"title": "编辑子标签",
"desc": "为 {{label}} 输入新的子标签",
- "descNoLabel": "为此跟踪对象输入新的子标签"
+ "descNoLabel": "为该追踪目标输入新的子标签"
},
"topScore": {
"label": "最高得分",
- "info": "最高分是跟踪对象的最高中位数得分,因此可能与搜索结果缩略图上显示的得分不同。"
+ "info": "最高分是追踪目标的中位分数最高值,因此可能与搜索结果缩略图中显示的分数有所不同。"
},
"estimatedSpeed": "预计速度",
- "objects": "对象",
+ "objects": "目标/物体",
"camera": "摄像头",
"zones": "区域",
"timestamp": "时间戳",
@@ -129,13 +135,13 @@
"findSimilar": "查找相似项",
"regenerate": {
"title": "重新生成",
- "label": "重新生成跟踪对象描述"
+ "label": "重新生成追踪目标的描述"
}
},
"description": {
"label": "描述",
- "placeholder": "跟踪对象的描述",
- "aiTips": "在跟踪对象的生命周期结束之前,Frigate 不会向您的生成式 AI 提供商请求描述。"
+ "placeholder": "追踪目标的描述",
+ "aiTips": "在追踪目标的目标全周期结束之前,Frigate 不会向您的生成式 AI 提供商请求描述。"
},
"expandRegenerationMenu": "展开重新生成菜单",
"regenerateFromSnapshot": "从快照重新生成",
@@ -146,12 +152,23 @@
},
"editLPR": {
"desc": "为 {{label}} 输入新的车牌值",
- "descNoLabel": "为检测到的对象输入新的车牌值",
+ "descNoLabel": "为检测到的目标输入新的车牌值",
"title": "编辑车牌"
},
"recognizedLicensePlate": "识别的车牌",
"snapshotScore": {
"label": "快照得分"
+ },
+ "score": {
+ "label": "分值"
+ },
+ "editAttributes": {
+ "title": "编辑属性",
+ "desc": "为 {{label}} 选择分类属性"
+ },
+ "attributes": "分类属性",
+ "title": {
+ "label": "标题"
}
},
"itemMenu": {
@@ -164,12 +181,12 @@
"aria": "下载快照"
},
"viewObjectLifecycle": {
- "label": "查看对象生命周期",
- "aria": "显示对象的生命周期"
+ "label": "查看目标全周期",
+ "aria": "显示目标的全周期"
},
"findSimilar": {
"label": "查找相似项",
- "aria": "查看相似的对象"
+ "aria": "查看相似的目标/物体"
},
"submitToPlus": {
"label": "提交至 Frigate+",
@@ -180,26 +197,105 @@
"aria": "在历史记录中查看"
},
"deleteTrackedObject": {
- "label": "删除此跟踪对象"
+ "label": "删除此追踪目标"
+ },
+ "addTrigger": {
+ "label": "添加触发器",
+ "aria": "为该追踪目标添加触发器"
+ },
+ "audioTranscription": {
+ "label": "转录",
+ "aria": "请求音频转录"
+ },
+ "showObjectDetails": {
+ "label": "显示目标轨迹"
+ },
+ "hideObjectDetails": {
+ "label": "隐藏目标轨迹"
+ },
+ "viewTrackingDetails": {
+ "label": "查看追踪详情",
+ "aria": "显示追踪详情"
+ },
+ "downloadCleanSnapshot": {
+ "label": "下载干净快照",
+ "aria": "下载干净快照"
}
},
"dialog": {
"confirmDelete": {
"title": "确认删除",
- "desc": "删除此跟踪对象将移除快照、所有已保存的嵌入数据以及任何关联的对象生命周期条目。但在历史视图中的录制视频不会被删除。
你确定要继续删除吗?"
+ "desc": "删除此追踪目标后,将移除快照、所有已保存的嵌入向量数据以及任何相关的目标追踪详情条目,但在 历史 页面中追踪目标的录制视频片段不会被删除。
你确定要继续删除该追踪目标吗?"
}
},
- "noTrackedObjects": "未找到跟踪对象",
- "fetchingTrackedObjectsFailed": "获取跟踪对象失败:{{errorMessage}}",
- "trackedObjectsCount_other": "{{count}} 个跟踪对象 ",
+ "noTrackedObjects": "未找到追踪目标",
+ "fetchingTrackedObjectsFailed": "获取追踪目标失败:{{errorMessage}}",
+ "trackedObjectsCount_other": "{{count}} 个追踪目标 ",
"searchResult": {
"deleteTrackedObject": {
"toast": {
- "success": "跟踪对象删除成功。",
- "error": "删除跟踪对象失败:{{errorMessage}}"
+ "success": "删除追踪目标成功。",
+ "error": "删除追踪目标失败:{{errorMessage}}"
}
},
- "tooltip": "与 {{type}} 匹配度为 {{confidence}}%"
+ "tooltip": "与 {{type}} 匹配度为 {{confidence}}%",
+ "previousTrackedObject": "上一个追踪目标",
+ "nextTrackedObject": "下一个追踪目标"
},
- "exploreMore": "浏览更多的 {{label}}"
+ "exploreMore": "浏览更多的 {{label}}",
+ "aiAnalysis": {
+ "title": "AI分析"
+ },
+ "concerns": {
+ "label": "风险等级"
+ },
+ "trackingDetails": {
+ "title": "追踪细节",
+ "noImageFound": "在该时间内没找到图片。",
+ "createObjectMask": "创建目标遮罩",
+ "adjustAnnotationSettings": "调整注释设置",
+ "scrollViewTips": "点击以查看该目标全周期中的关键时刻。",
+ "autoTrackingTips": "自动追踪摄像头的边框定位可能不准确。",
+ "count": "{{first}} / {{second}}",
+ "trackedPoint": "追踪点",
+ "lifecycleItemDesc": {
+ "visible": "已检测到 {{label}}",
+ "entered_zone": "{{label}} 进入 {{zones}}",
+ "active": "{{label}} 正在活动",
+ "stationary": "{{label}} 变为静止",
+ "attribute": {
+ "faceOrLicense_plate": "检测到 {{label}} 的 {{attribute}} 属性",
+ "other": "{{label}} 被识别为 {{attribute}}"
+ },
+ "gone": "{{label}} 离开",
+ "heard": "听到 {{label}}",
+ "external": "已检测到 {{label}}",
+ "header": {
+ "zones": "区",
+ "ratio": "比例",
+ "area": "大小",
+ "score": "分数"
+ }
+ },
+ "annotationSettings": {
+ "title": "标记设置",
+ "showAllZones": {
+ "title": "显示所有区",
+ "desc": "在目标进入区域的帧中始终显示区域框。"
+ },
+ "offset": {
+ "label": "标记偏移量",
+ "desc": "此数据来自摄像头的检测视频流,但叠加在录制视频流的画面上。两个视频流可能不会完全同步,因此边框与画面可能无法完全对齐。可以使用此设置将标记在时间轴上向前或向后偏移,以更好地与录制画面对齐。",
+ "millisecondsToOffset": "用于偏移检测标记的毫秒数。 默认值:0",
+ "tips": "提示:假设有一段人从左向右走的事件录制,如果事件时间轴中的边框始终在人的左侧(即后方),则应该减小偏移值;反之,如果边框始终领先于人物,则应增大偏移值。",
+ "toast": {
+ "success": "{{camera}} 的标记偏移量已保存。"
+ }
+ }
+ },
+ "carousel": {
+ "previous": "上一张图",
+ "next": "下一张图"
+ }
+ }
}
diff --git a/web/public/locales/zh-CN/views/exports.json b/web/public/locales/zh-CN/views/exports.json
index b22d035f1..3270dc4e5 100644
--- a/web/public/locales/zh-CN/views/exports.json
+++ b/web/public/locales/zh-CN/views/exports.json
@@ -13,5 +13,11 @@
"error": {
"renameExportFailed": "重命名导出失败:{{errorMessage}}"
}
+ },
+ "tooltip": {
+ "shareExport": "分享导出",
+ "downloadVideo": "下载视频",
+ "editName": "编辑名称",
+ "deleteExport": "删除导出"
}
}
diff --git a/web/public/locales/zh-CN/views/faceLibrary.json b/web/public/locales/zh-CN/views/faceLibrary.json
index 7fb906bcd..b8e9a9501 100644
--- a/web/public/locales/zh-CN/views/faceLibrary.json
+++ b/web/public/locales/zh-CN/views/faceLibrary.json
@@ -1,14 +1,15 @@
{
"description": {
- "addFace": "我们将引导你如何向人脸库中添加新的特征库。",
- "placeholder": "请输入此特征库的名称",
- "invalidName": "名称无效。名称只能包含字母、数字、空格、撇号、下划线和连字符。"
+ "addFace": "我们将引导你如何向人脸库中添加新的合集。",
+ "placeholder": "请输入此合集的名称",
+ "invalidName": "名称无效。名称只能包含字母、数字、空格、撇号、下划线和连字符。",
+ "nameCannotContainHash": "名称中不允许包含“#”符号。"
},
"details": {
"person": "人",
"confidence": "置信度",
"face": "人脸详情",
- "faceDesc": "生成此人脸特征的跟踪对象详细信息",
+ "faceDesc": "生成此人脸特征的追踪目标详细信息",
"timestamp": "时间戳",
"subLabelScore": "子标签得分",
"scoreInfo": "子标签分数是基于所有识别到的人脸置信度的加权评分,因此可能与快照中显示的分数有所不同。",
@@ -23,18 +24,19 @@
"title": "创建特征库",
"desc": "创建一个新的特征库",
"new": "新建人脸",
- "nextSteps": "建议按以下步骤建立可靠的特征库:使用训练选项卡为每个检测到的人员选择并训练图像 优先使用正脸图像以获得最佳效果,尽可能避免使用侧脸图像进行训练 "
+ "nextSteps": "建议按以下步骤建立可靠的数据集:使用近期识别记录选项卡为每个检测到的人员选择并训练图像 优先使用正脸图像以获得最佳效果,尽可能避免使用侧脸图像进行训练 "
},
"train": {
- "title": "训练",
- "aria": "选择训练",
- "empty": "近期未检测到人脸识别操作"
+ "title": "近期识别记录",
+ "aria": "选择近期识别记录",
+ "empty": "近期未检测到人脸识别操作",
+ "titleShort": "近期"
},
"selectItem": "选择 {{item}}",
"selectFace": "选择人脸",
"deleteFaceLibrary": {
"title": "删除名称",
- "desc": "确定要删除特征库 {{name}} 吗?此操作将永久删除所有关联的人脸特征数据。"
+ "desc": "确定要删除数据集 {{name}} 吗?此操作将永久删除所有关联的人脸特征数据。"
},
"button": {
"deleteFaceAttempts": "删除人脸",
@@ -49,7 +51,7 @@
"selectImage": "请选择图片文件。"
},
"dropActive": "拖动图片文件到这里…",
- "dropInstructions": "拖动图片文件到此处或点击选择",
+ "dropInstructions": "拖动或粘贴图片文件到此处,也可以点击选择文件",
"maxSize": "最大文件大小:{{size}}MB"
},
"readTheDocs": "阅读文档",
@@ -62,14 +64,14 @@
"deletedFace_other": "成功删除 {{count}} 个 人脸特征。",
"deletedName_other": "成功删除 {{count}} 个 人脸特征。",
"trainedFace": "人脸特征训练成功。",
- "updatedFaceScore": "更新人脸特征评分成功。",
+ "updatedFaceScore": "更新 {{name}} 人脸特征评分({{score}})成功。",
"renamedFace": "成功重命名人脸为{{name}}"
},
"error": {
"uploadingImageFailed": "图片上传失败:{{errorMessage}}",
"addFaceLibraryFailed": "人脸命名失败:{{errorMessage}}",
"deleteFaceFailed": "删除失败:{{errorMessage}}",
- "deleteNameFailed": "特征集删除失败:{{errorMessage}}",
+ "deleteNameFailed": "数据集删除失败:{{errorMessage}}",
"trainFailed": "训练失败:{{errorMessage}}",
"updateFaceScoreFailed": "更新人脸评分失败:{{errorMessage}}",
"renameFaceFailed": "重命名人脸失败:{{errorMessage}}"
@@ -87,7 +89,7 @@
"desc": "为 {{name}} 输入新的名称",
"title": "重命名人脸"
},
- "collections": "特征库",
+ "collections": "合集",
"deleteFaceAttempts": {
"desc_other": "你确定要删除 {{count}} 张人脸数据吗?此操作不可撤销。",
"title": "删除人脸"
diff --git a/web/public/locales/zh-CN/views/live.json b/web/public/locales/zh-CN/views/live.json
index 505781c4e..0f025b5cc 100644
--- a/web/public/locales/zh-CN/views/live.json
+++ b/web/public/locales/zh-CN/views/live.json
@@ -43,7 +43,15 @@
"label": "点击将PTZ摄像头画面居中"
}
},
- "presets": "PTZ摄像头预设"
+ "presets": "PTZ摄像头预设",
+ "focus": {
+ "in": {
+ "label": "PTZ摄像头聚焦"
+ },
+ "out": {
+ "label": "PTZ摄像头拉远"
+ }
+ }
},
"camera": {
"enable": "开启摄像头",
@@ -79,7 +87,7 @@
},
"manualRecording": {
"title": "按需录制",
- "tips": "根据此摄像头的录制保留设置,手动启动事件。",
+ "tips": "根据此摄像头的录像存储设置,可以下载即时快照或手动触发事件记录。",
"playInBackground": {
"label": "后台播放",
"desc": "启用此选项可在播放器隐藏时继续视频流播放。"
@@ -107,11 +115,11 @@
"title": "视频流",
"audio": {
"tips": {
- "title": "音频必须从摄像头输出并在 go2rtc 中配置为此视频流使用。",
+ "title": "必须要摄像头支持音频,以及需要 go2rtc 支持并配置。",
"documentation": "阅读文档 "
},
"available": "此视频流支持音频",
- "unavailable": "此视频流不支持音频"
+ "unavailable": "此视频流不支持音频传输"
},
"twoWayTalk": {
"tips": "您的设备必须支持此功能,并且必须配置 WebRTC 以支持双向对讲。",
@@ -126,16 +134,20 @@
"playInBackground": {
"label": "后台播放",
"tips": "启用此选项可在播放器隐藏时继续视频流播放。"
+ },
+ "debug": {
+ "picker": "调试模式下无法切换视频流。调试将始终使用检测(detect)功能的视频流。"
}
},
"cameraSettings": {
"title": "{{camera}} 设置",
"cameraEnabled": "摄像头已启用",
- "objectDetection": "对象检测",
+ "objectDetection": "目标检测",
"recording": "录制",
"snapshots": "快照",
"audioDetection": "音频检测",
- "autotracking": "自动跟踪"
+ "autotracking": "自动追踪",
+ "transcription": "音频转录"
},
"history": {
"label": "显示历史录像"
@@ -143,16 +155,45 @@
"effectiveRetainMode": {
"modes": {
"all": "全部",
- "motion": "运动",
- "active_objects": "活动对象"
+ "motion": "画面变动",
+ "active_objects": "活动目标"
},
"notAllTips": "您的 {{source}} 录制保留配置设置为 mode: {{effectiveRetainMode}},因此此按需录制将仅保留包含 {{effectiveRetainModeName}} 的片段。"
},
"editLayout": {
"label": "编辑布局",
"group": {
- "label": "编辑摄像机分组"
+ "label": "编辑摄像头分组"
},
"exitEdit": "退出编辑"
+ },
+ "transcription": {
+ "enable": "启用实时音频转录",
+ "disable": "关闭实时音频转录"
+ },
+ "noCameras": {
+ "title": "未设置摄像头",
+ "description": "准备开始连接摄像头至 Frigate 。",
+ "buttonText": "添加摄像头",
+ "restricted": {
+ "title": "无可用摄像头",
+ "description": "你没有权限查看此分组中的任何摄像头。"
+ },
+ "default": {
+ "title": "没有配置摄像头",
+ "description": "现在就将摄像头接入到 Frigate 吧。",
+ "buttonText": "添加摄像头"
+ },
+ "group": {
+ "title": "摄像头组目前为空",
+ "description": "该摄像头组未分配或启动了摄像头。",
+ "buttonText": "管理摄像头组"
+ }
+ },
+ "snapshot": {
+ "takeSnapshot": "下载即时快照",
+ "noVideoSource": "当前无可用于快照的视频源。",
+ "captureFailed": "捕获快照失败。",
+ "downloadStarted": "快照下载已开始。"
}
}
diff --git a/web/public/locales/zh-CN/views/search.json b/web/public/locales/zh-CN/views/search.json
index b2f8c6d12..51fe47c8e 100644
--- a/web/public/locales/zh-CN/views/search.json
+++ b/web/public/locales/zh-CN/views/search.json
@@ -9,10 +9,10 @@
"filterInformation": "筛选信息",
"filterActive": "筛选器已激活"
},
- "trackedObjectId": "跟踪对象 ID",
+ "trackedObjectId": "追踪目标 ID",
"filter": {
"label": {
- "cameras": "摄像机",
+ "cameras": "摄像头",
"labels": "标签",
"zones": "区域",
"sub_labels": "子标签",
@@ -26,7 +26,8 @@
"max_speed": "最高速度",
"recognized_license_plate": "识别的车牌",
"has_clip": "包含片段",
- "has_snapshot": "包含快照"
+ "has_snapshot": "包含快照",
+ "attributes": "属性"
},
"searchType": {
"thumbnail": "缩略图",
diff --git a/web/public/locales/zh-CN/views/settings.json b/web/public/locales/zh-CN/views/settings.json
index fb92e6b7b..b1e0a78d8 100644
--- a/web/public/locales/zh-CN/views/settings.json
+++ b/web/public/locales/zh-CN/views/settings.json
@@ -5,24 +5,30 @@
"camera": "摄像头设置 - Frigate",
"classification": "分类设置 - Frigate",
"masksAndZones": "遮罩和区域编辑器 - Frigate",
- "motionTuner": "运动调整器 - Frigate",
+ "motionTuner": "画面变动调整 - Frigate",
"object": "调试 - Frigate",
- "general": "常规设置 - Frigate",
+ "general": "页面设置 - Frigate",
"frigatePlus": "Frigate+ 设置 - Frigate",
"notifications": "通知设置 - Frigate",
- "enrichments": "增强功能设置 - Frigate"
+ "enrichments": "增强功能设置 - Frigate",
+ "cameraManagement": "管理摄像头 - Frigate",
+ "cameraReview": "摄像头核查设置 - Frigate"
},
"menu": {
"ui": "界面设置",
"classification": "分类设置",
"cameras": "摄像头设置",
"masksAndZones": "遮罩/ 区域",
- "motionTuner": "运动调整器",
+ "motionTuner": "画面变动调整",
"debug": "调试",
"users": "用户",
"notifications": "通知",
"frigateplus": "Frigate+",
- "enrichments": "增强功能"
+ "enrichments": "增强功能",
+ "triggers": "触发器",
+ "roles": "权限组",
+ "cameraManagement": "管理",
+ "cameraReview": "核查"
},
"dialog": {
"unsavedChanges": {
@@ -35,7 +41,7 @@
"noCamera": "没有摄像头"
},
"general": {
- "title": "常规设置",
+ "title": "页面设置",
"liveDashboard": {
"title": "实时监控面板",
"automaticLiveView": {
@@ -45,6 +51,14 @@
"playAlertVideos": {
"label": "播放警报视频",
"desc": "默认情况下,实时监控页面上的最新警报会以一小段循环视频的形式进行播放。禁用此选项将仅显示浏览器本地缓存的静态图片。"
+ },
+ "displayCameraNames": {
+ "label": "始终显示摄像头名称",
+ "desc": "在有多摄像头情况下的实时监控页面,将始终显示摄像头名称标签。"
+ },
+ "liveFallbackTimeout": {
+ "label": "实时监控播放器回退超时",
+ "desc": "当摄像头的高清实时监控流不可用时,将在此时间后回退到低带宽模式。默认值:3秒。"
}
},
"storedLayouts": {
@@ -164,12 +178,12 @@
"readTheDocumentation": "阅读文档",
"noDefinedZones": "该摄像头没有设置区域。",
"objectAlertsTips": "所有 {{alertsLabels}} 对象在 {{cameraName}} 下都将显示为警报。",
- "zoneObjectAlertsTips": "所有 {{alertsLabels}} 对象在 {{cameraName}} 下的 {{zone}} 区内都将显示为警报。",
- "objectDetectionsTips": "所有未在 {{cameraName}} 归类的 {{detectionsLabels}} 对象,无论它位于哪个区,都将显示为检测。",
+ "zoneObjectAlertsTips": "所有 {{alertsLabels}} 类的目标或物体在 {{cameraName}} 下的 {{zone}} 区内都将显示为警报。",
+ "objectDetectionsTips": "所有未在 {{cameraName}} 归类的 {{detectionsLabels}} 目标或物体,无论它位于哪个区,都将显示为检测。",
"zoneObjectDetectionsTips": {
- "text": "所有未在 {{cameraName}} 上归类为 {{detectionsLabels}} 的对象在 {{zone}} 区都将显示为检测。",
- "notSelectDetections": "所有在 {{cameraName}} 下的 {{zone}} 区内检测到的 {{detectionsLabels}} 对象,如果它未归类为警报,无论它位于哪个区,都将显示为检测。",
- "regardlessOfZoneObjectDetectionsTips": "所有未在 {{cameraName}} 归类的 {{detectionsLabels}} 对象,无论它位于哪个区域,都将显示为检测。"
+ "text": "所有未在 {{cameraName}} 上归类为 {{detectionsLabels}} 的目标或物体在 {{zone}} 区内都将显示为检测。",
+ "notSelectDetections": "所有在 {{cameraName}} 下的 {{zone}} 区内检测到的 {{detectionsLabels}} 目标或物体,如果它未归类为警报,无论它位于哪个区,都将显示为检测。",
+ "regardlessOfZoneObjectDetectionsTips": "所有未在 {{cameraName}} 归类的 {{detectionsLabels}} 目标或物体,无论它位于哪个区域,都将显示为检测。"
},
"selectAlertsZones": "选择警报区",
"selectDetectionsZones": "选择检测区域",
@@ -178,6 +192,44 @@
"success": "核查分级配置已保存。请重启 Frigate 以应用更改。"
},
"unsavedChanges": "{{camera}} 的核查分类设置未保存"
+ },
+ "object_descriptions": {
+ "title": "生成式AI对象描述",
+ "desc": "临时启用/禁用此摄像头的生成式AI对象描述功能。禁用后,系统将不再请求该摄像头追踪对象的AI生成描述。"
+ },
+ "review_descriptions": {
+ "title": "生成式AI核查描述",
+ "desc": "临时启用/禁用本摄像头的生成式AI核查描述功能。禁用后,系统将不再为该摄像头的核查项目请求AI生成的描述内容。"
+ },
+ "addCamera": "添加新摄像头",
+ "editCamera": "编辑摄像头:",
+ "selectCamera": "选择摄像头",
+ "backToSettings": "返回摄像头设置",
+ "cameraConfig": {
+ "add": "添加摄像头",
+ "edit": "编辑摄像头",
+ "description": "配置摄像头设置,包括视频流输入和视频流功能选择。",
+ "name": "摄像头名称",
+ "nameRequired": "摄像头名称为必填项",
+ "nameInvalid": "摄像头名称只能包含字母、数字、下划线或连字符",
+ "namePlaceholder": "比如:front_door",
+ "enabled": "开启",
+ "ffmpeg": {
+ "inputs": "视频流输入",
+ "path": "视频流路径",
+ "pathRequired": "视频流路径为必填项",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "功能",
+ "rolesRequired": "至少需要指定一个功能",
+ "rolesUnique": "每个功能(音频、检测、录制)只能用于一个视频流,不能够重复分配到多个视频流",
+ "addInput": "添加视频流输入",
+ "removeInput": "移除视频流输入",
+ "inputsRequired": "至少需要一个视频流"
+ },
+ "toast": {
+ "success": "摄像头 {{cameraName}} 保存已保存"
+ },
+ "nameLength": "摄像头名称必须少于24个字符。"
}
},
"masksAndZones": {
@@ -199,7 +251,8 @@
"mustNotBeSameWithCamera": "区域名称不能与摄像头名称相同。",
"alreadyExists": "该摄像头已有相同的区域名称。",
"mustNotContainPeriod": "区域名称不能包含句点。",
- "hasIllegalCharacter": "区域名称包含非法字符。"
+ "hasIllegalCharacter": "区域名称包含非法字符。",
+ "mustHaveAtLeastOneLetter": "区域名称必须至少包含一个字母。"
}
},
"distance": {
@@ -229,7 +282,7 @@
},
"delete": {
"title": "确认删除",
- "desc": "你确定要删除{{type}} {{name}} 吗?",
+ "desc": "你确定要删除{{type}} “{{name}}” 吗?",
"success": "{{name}} 已被删除。"
},
"error": {
@@ -246,7 +299,7 @@
"label": "区域",
"documentTitle": "编辑区域 - Frigate",
"desc": {
- "title": "该功能允许你定义特定区域,以便你可以确定特定对象是否在该区域内。",
+ "title": "该功能允许你定义特定区域,以便你可以确定特定目标或物体是否在该区域内。",
"documentation": "文档"
},
"add": "添加区域",
@@ -256,21 +309,21 @@
"name": {
"title": "区域名称",
"inputPlaceHolder": "请输入名称…",
- "tips": "名称至少包含两个字符,且不能和摄像头或其他区域同名。
当前仅支持英文与数字组合。"
+ "tips": "名称至少包含两个字符,且不能和摄像头名或该摄像头下的其他区域同名。"
},
"inertia": {
"title": "惯性",
- "desc": "识别指定对象前该对象必须在这个区域内出现了多少帧。默认值:3"
+ "desc": "识别指定目标前该目标必须在这个区域内出现了多少帧。默认值:3"
},
"loiteringTime": {
"title": "停留时间",
- "desc": "设置对象必须在区域中活动的最小时间(单位为秒)。默认值:0"
+ "desc": "设置目标必须在区域中至少要活动多少时间(单位为秒)。默认值:0"
},
"objects": {
- "title": "对象",
- "desc": "将在此区域应用的对象列表。"
+ "title": "目标/物体",
+ "desc": "将在此区域应用的目标/物体类别列表。"
},
- "allObjects": "所有对象",
+ "allObjects": "所有目标/物体",
"speedEstimation": {
"title": "速度估算",
"desc": "启用此区域内物体的速度估算。该区域必须恰好包含 4 个点。",
@@ -291,100 +344,100 @@
}
},
"toast": {
- "success": "区域 ({{zoneName}}) 已保存。请重启 Frigate 以应用更改。"
+ "success": "区域 ({{zoneName}}) 已保存。"
}
},
"motionMasks": {
- "label": "运动遮罩",
- "documentTitle": "编辑运动遮罩 - Frigate",
+ "label": "画面变动遮罩",
+ "documentTitle": "编辑画面变动遮罩 - Frigate",
"desc": {
- "title": "运动遮罩用于防止触发不必要的运动类型。过度的设置遮罩将使对象更加难以被追踪。",
+ "title": "画面变动遮罩用于防止触发不必要的画面变动检测。过度的设置遮罩将使目标更加难以被追踪。",
"documentation": "文档"
},
- "add": "添加运动遮罩",
- "edit": "编辑运动遮罩",
+ "add": "添加画面变动遮罩",
+ "edit": "编辑画面变动遮罩",
"context": {
- "title": "运动遮罩用于防止不需要的运动类型触发检测(例如:树枝、摄像头画面显示的时间等)。运动遮罩需要谨慎使用,过度的遮罩会导致追踪对象变得更加困难。",
+ "title": "画面变动遮罩用于防止不需要的画面变动触发检测(例如:容易被风吹动的树枝、摄像头画面上显示的时间等)。画面变动遮罩应谨慎使用,过度的遮罩会导致追踪目标变得更加困难。",
"documentation": "阅读文档"
},
"point_other": "{{count}} 点",
"clickDrawPolygon": "在图像上点击添加点绘制多边形区域。",
"polygonAreaTooLarge": {
- "title": "运动遮罩的大小达到了摄像头画面的{{polygonArea}}%。不建议设置太大的运动遮罩。",
- "tips": "运动遮罩不会阻止检测到对象,你应该使用区域来限制检测对象。",
+ "title": "画面变动遮罩的大小达到了摄像头画面的{{polygonArea}}%。不建议设置太大的画面变动遮罩。",
+ "tips": "画面变动遮罩并不会使该区域无法检测到指定目标/物体,如有需要,你应该使用 区域 来限制检测的目标/物体类型。",
"documentation": "阅读文档"
},
"toast": {
"success": {
- "title": "{{polygonName}} 已保存。请重启 Frigate 以应用更改。",
- "noName": "运动遮罩已保存。请重启 Frigate 以应用更改。"
+ "title": "{{polygonName}} 已保存。",
+ "noName": "画面变动遮罩已保存。"
}
}
},
"objectMasks": {
- "label": "对象遮罩",
- "documentTitle": "编辑对象遮罩 - Frigate",
+ "label": "目标遮罩",
+ "documentTitle": "编辑目标遮罩 - Frigate",
"desc": {
- "title": "对象过滤器用于防止特定位置的指定对象被误报。",
+ "title": "目标过滤器用于防止特定位置出现对某个目标/物体的误报。",
"documentation": "文档"
},
- "add": "添加对象遮罩",
- "edit": "编辑对象遮罩",
- "context": "对象过滤器用于防止特定位置的指定对象被误报。",
+ "add": "添加目标遮罩",
+ "edit": "编辑目标遮罩",
+ "context": "目标过滤器用于防止特定位置的指定目标会误报。",
"point_other": "{{count}} 点",
"clickDrawPolygon": "在图像上点击添加点绘制多边形区域。",
"objects": {
- "title": "对象",
- "desc": "将应用于此对象遮罩的对象类型。",
- "allObjectTypes": "所有对象类型"
+ "title": "目标/物体",
+ "desc": "将应用于此目标遮罩的目标或物体类型。",
+ "allObjectTypes": "所有目标或物体类型"
},
"toast": {
"success": {
- "title": "{{polygonName}} 已保存。请重启 Frigate 以应用更改。",
- "noName": "对象遮罩已保存。请重启 Frigate 以应用更改。"
+ "title": "{{polygonName}} 已保存。",
+ "noName": "目标遮罩已保存。"
}
}
},
"restart_required": "需要重启(遮罩与区域已修改)",
- "motionMaskLabel": "运动遮罩 {{number}}",
- "objectMaskLabel": "对象遮罩 {{number}}({{label}})"
+ "motionMaskLabel": "画面变动遮罩 {{number}}",
+ "objectMaskLabel": "目标/物体遮罩 {{number}}({{label}})"
},
"motionDetectionTuner": {
- "title": "运动检测调整器",
+ "title": "画面变动检测调整",
"desc": {
- "title": "Frigate 将使用运动检测作为首个步骤,以确认一帧画面中是否有对象需要使用对象检测。",
- "documentation": "阅读有关运动检测的文档"
+ "title": "Frigate 将首先使用画面变动检测来确认每一帧画面中是否有变动的区域,然后再对该区域使用目标检测。",
+ "documentation": "阅读有关画面变动检测的文档"
},
"Threshold": {
"title": "阈值",
- "desc": "阈值决定像素亮度高于多少时会被认为是运动。默认值:30"
+ "desc": "阈值决定像素亮度变化达到多少时会被认为是画面变动。默认值:30"
},
"contourArea": {
"title": "轮廓面积",
- "desc": "轮廓面积决定哪些变化的像素组符合运动条件。默认值:10"
+ "desc": "轮廓面积值用于判断产生了多大的变化区域可被认定为画面变动。默认值:10"
},
"improveContrast": {
"title": "提高对比度",
"desc": "提高较暗场景的对比度。默认值:启用"
},
"toast": {
- "success": "运动设置已保存。"
+ "success": "画面变动设置已保存。"
},
- "unsavedChanges": "{{camera}} 的运动调整器设置未保存"
+ "unsavedChanges": "{{camera}} 的画面变动调整设置未保存"
},
"debug": {
"title": "调试",
- "detectorDesc": "Frigate 将使用检测器({{detectors}})来检测摄像头视频流中的对象。",
- "desc": "调试界面将实时显示被追踪的对象以及统计信息,对象列表将显示检测到的对象和延迟显示的概览。",
+ "detectorDesc": "Frigate 将使用检测器({{detectors}})来检测摄像头视频流中的目标或物体。",
+ "desc": "调试界面将实时显示被追踪的目标以及统计信息,目标列表将显示检测到的目标和延迟显示的概览。",
"debugging": "调试选项",
- "objectList": "对象列表",
- "noObjects": "没有对象",
+ "objectList": "目标列表",
+ "noObjects": "没有目标",
"boundingBoxes": {
"title": "边界框",
- "desc": "将在被追踪的对象周围显示边界框",
+ "desc": "将在被追踪的目标周围显示边界框",
"colors": {
- "label": "对象边界框颜色定义",
- "info": "启用后,将会为每个对象标签分配不同的颜色 深蓝色细线代表该对象在当前时间点未被检测到 灰色细线代表检测到的物体静止不动 粗线表示该对象为自动跟踪的主体(在启动时) "
+ "label": "目标边界框颜色定义",
+ "info": "启用后,将会为每个目标的标签分配不同的颜色 深蓝色细线代表该目标或物体在当前时间点未被检测到 灰色细线代表检测到的目标或物体静止不动 粗线表示在启动自动追踪时,该目标为自动追踪的主体 "
}
},
"timestamp": {
@@ -396,28 +449,41 @@
"desc": "显示已定义的区域图层"
},
"mask": {
- "title": "运动遮罩",
- "desc": "显示运动遮罩图层"
+ "title": "画面变动遮罩",
+ "desc": "显示画面变动遮罩图层"
},
"motion": {
- "title": "运动区域框",
- "desc": "在检测到运动的区域显示区域框",
- "tips": "运动区域框
将在当前检测到运动的区域内显示红色区域框。
"
+ "title": "画面变动区域框",
+ "desc": "在检测到画面变动的区域显示区域框",
+ "tips": "画面变动区域框
将在当前检测到画面变动的区域内显示红色区域框。
"
},
"regions": {
"title": "范围",
- "desc": "显示发送到运动检测器感兴趣范围的框",
+ "desc": "显示发送给目标检测器感兴趣的区域框",
"tips": "范围框
将在帧中发送到目标检测器的感兴趣范围上叠加绿色框。
"
},
"objectShapeFilterDrawing": {
- "title": "允许绘制“对象形状过滤器”",
+ "title": "允许绘制“目标形状过滤器”",
"desc": "在图像上绘制矩形,以查看区域和比例详细信息",
- "tips": "启用此选项,能够在摄像头图像上绘制矩形,将显示其区域和比例。然后,您可以使用这些值在配置中设置对象形状过滤器参数。",
+ "tips": "启用此选项,能够在摄像头画面上绘制矩形,将显示其区域和比例。你可以通过使用这些值在配置中设置目标形状过滤器的参数。",
"document": "阅读文档 ",
"score": "分数",
"ratio": "比例",
"area": "区域"
- }
+ },
+ "paths": {
+ "title": "行动轨迹",
+ "desc": "显示被追踪目标的行动轨迹关键点",
+ "tips": "行动轨迹
将使用线条和点来标示被追踪目标在其活动周期内移动的关键位置点。
"
+ },
+ "audio": {
+ "title": "音频",
+ "noAudioDetections": "未检测到音频事件",
+ "score": "分值",
+ "currentRMS": "当前均方根值(RMS)",
+ "currentdbFS": "当前满量程相对分贝值(dbFS)"
+ },
+ "openCameraWebUI": "打开 {{camera}} 的管理页面"
},
"users": {
"title": "用户",
@@ -447,7 +513,7 @@
"role": "权限组",
"noUsers": "未找到用户。",
"changeRole": "更改用户角色",
- "password": "密码",
+ "password": "修改密码",
"deleteUser": "删除用户"
},
"dialog": {
@@ -472,7 +538,16 @@
"veryStrong": "非常强"
},
"match": "密码匹配",
- "notMatch": "密码不匹配"
+ "notMatch": "密码不匹配",
+ "show": "显示密码",
+ "hide": "隐藏密码",
+ "requirements": {
+ "title": "密码要求:",
+ "length": "至少需要 12 位字符",
+ "uppercase": "至少一个大写字母",
+ "digit": "至少一位数字",
+ "special": "至少一个特殊符号 (!@#$%^&*(),.?\":{}|<>)"
+ }
},
"newPassword": {
"title": "新密码",
@@ -482,7 +557,11 @@
}
},
"usernameIsRequired": "用户名为必填项",
- "passwordIsRequired": "必须输入密码"
+ "passwordIsRequired": "必须输入密码",
+ "currentPassword": {
+ "title": "当前密码",
+ "placeholder": "请输入当前密码"
+ }
},
"createUser": {
"title": "创建新用户",
@@ -500,7 +579,12 @@
"setPassword": "设置密码",
"desc": "创建一个强密码来保护此账户。",
"doNotMatch": "两次输入密码不匹配",
- "cannotBeEmpty": "密码不能为空"
+ "cannotBeEmpty": "密码不能为空",
+ "currentPasswordRequired": "当前密码为必填",
+ "incorrectCurrentPassword": "当前密码错误",
+ "passwordVerificationFailed": "验证密码失败",
+ "multiDeviceWarning": "其他已登录的设备将需要在 {{refresh_time}} 内重新登录。",
+ "multiDeviceAdmin": "你也可以通过轮换你的 JWT 密钥,强制所有用户立即重新登录验证。"
},
"changeRole": {
"title": "更改用户权限组",
@@ -510,7 +594,8 @@
"viewer": "成员",
"viewerDesc": "仅能够查看实时监控面板、核查、浏览和导出功能。",
"adminDesc": "完全功能与访问权限。",
- "intro": "为该用户选择一个合适的权限组:"
+ "intro": "为该用户选择一个合适的权限组:",
+ "customDesc": "自定义特定摄像头的访问规则。"
},
"select": "选择权限组"
}
@@ -619,15 +704,15 @@
"enrichments": {
"title": "增强功能设置",
"birdClassification": {
- "desc": "鸟类分类通过量化的TensorFlow模型识别已知鸟类。当识别到已知鸟类时,其通用名称将作为子标签(sub_label)添加。此信息包含在用户界面、筛选器以及通知中。",
+ "desc": "鸟类分类通过量化的 TensorFlow 模型识别已知鸟类。当识别到已知鸟类时,其通用名称将作为子标签(sub_label)添加。此信息包含在用户界面、筛选器以及通知中。",
"title": "鸟类分类"
},
"semanticSearch": {
"reindexNow": {
- "desc": "重建索引将为所有跟踪对象重新生成特征向量。该过程将在后台运行,可能会使CPU满载,所需时间取决于跟踪对象的数量。",
+ "desc": "重建索引将为所有追踪的目标重新生成特征向量信息。该过程将在后台进行,期间可能会使 CPU 满载,所需时间取决于追踪目标的数量。",
"label": "立即重建索引",
"confirmTitle": "确认重建索引",
- "confirmDesc": "确定要为所有跟踪对象重建特征向量索引吗?此过程将在后台运行,但可能会导致CPU满载并耗费较长时间。您可以在 浏览 页面查看进度。",
+ "confirmDesc": "确定要为所有追踪目标重建特征向量索引信息吗?此过程将在后台进行,但可能会导致CPU满载并耗费较长时间。您可以在 浏览 页面查看进度。",
"confirmButton": "重建索引",
"success": "重建索引已成功启动。",
"alreadyInProgress": "重建索引已在执行中。",
@@ -638,19 +723,19 @@
"desc": "用于语义搜索的语言模型大小。",
"small": {
"title": "小",
- "desc": "将使用 小模型。该模型将使用少量的内存,在CPU上也能较快的运行,质量较好。"
+ "desc": "将使用 小模型。该模型使用的内存较少,在 CPU 上也能较快的运行,质量较好。"
},
"large": {
"title": "大",
- "desc": "将使用 大模型。该选项使用了完整的Jina模型,在合适的时候将自动使用GPU。"
+ "desc": "将使用 大模型。该选项使用了完整的 Jina 模型,条件允许的情况下将自动使用 GPU 运行。"
}
},
"title": "分类搜索",
- "desc": "Frigate中的语义搜索功能允许您通过使用图像本身、用户自定义的文本描述,或自动生成的文本描述等方式在核查项目中查找被追踪对象。",
+ "desc": "Frigate 中的语义搜索功能将能够让你通过图片、用户自定义的文本描述,或自动生成的文本描述等方式在核查项目中查找目标/物体。",
"readTheDocumentation": "阅读文档"
},
"licensePlateRecognition": {
- "desc": "Frigate 可以识别车辆的车牌,并自动将检测到的字符添加到 recognized_license_plate 字段中,或将已知名称作为子标签添加到汽车类型的对象中。常见的使用场景可能是读取驶入车道的汽车车牌或经过街道的汽车车牌。",
+ "desc": "Frigate 可以识别车辆的车牌,并自动将检测到的字符添加到 识别的车牌(recognized_license_plate)字段中,或将已知车牌对应的名称作为子标签添加到该车辆目标中。该功能常用于识别驶入车道的车辆车牌或经过街道的车辆车牌。",
"title": "车牌识别",
"readTheDocumentation": "阅读文档"
},
@@ -663,11 +748,11 @@
"desc": "用于人脸识别的模型大小。",
"small": {
"title": "小",
- "desc": "将使用小模型。该选项采用FaceNet人脸特征提取模型,可在大多数CPU上高效运行。"
+ "desc": "将使用小模型。该选项采用 FaceNet 人脸特征提取模型,可在大多数 CPU 上高效运行。"
},
"large": {
"title": "大",
- "desc": "将使用大模型。该选项使用ArcFace人脸特征提取模型,在需要的时候自动使用GPU运行。"
+ "desc": "将使用大模型。该选项使用 ArcFace 人脸特征提取模型,条件允许的情况下将自动使用 GPU 运行。"
}
}
},
@@ -677,5 +762,545 @@
},
"unsavedChanges": "增强功能设置未保存",
"restart_required": "需要重启(增强功能设置已保存)"
+ },
+ "triggers": {
+ "documentTitle": "触发器",
+ "management": {
+ "title": "触发器",
+ "desc": "管理 {{camera}} 的触发器。你可以选择“缩略图”类型,将通过与追踪目标相似的缩略图来触发;也可以通过“描述”类型,与你描述的文本相似来触发(中文描述需要使用 jina v2模型,对配置要求更高)。"
+ },
+ "addTrigger": "添加触发器",
+ "table": {
+ "name": "名称",
+ "type": "类型",
+ "content": "触发内容",
+ "threshold": "阈值",
+ "actions": "动作",
+ "noTriggers": "此摄像头未配置任何触发器。",
+ "edit": "编辑",
+ "deleteTrigger": "删除触发器",
+ "lastTriggered": "最后一个触发项"
+ },
+ "type": {
+ "thumbnail": "缩略图",
+ "description": "描述"
+ },
+ "actions": {
+ "alert": "标记为警报",
+ "notification": "发送通知",
+ "sub_label": "添加子标签",
+ "attribute": "添加属性"
+ },
+ "dialog": {
+ "createTrigger": {
+ "title": "创建触发器",
+ "desc": "为摄像头 {{camera}} 创建触发器"
+ },
+ "editTrigger": {
+ "title": "编辑触发器",
+ "desc": "编辑摄像头 {{camera}} 的触发器设置"
+ },
+ "deleteTrigger": {
+ "title": "删除触发器",
+ "desc": "你确定要删除触发器 {{triggerName}} 吗?此操作不可撤销。"
+ },
+ "form": {
+ "name": {
+ "title": "名称",
+ "placeholder": "触发器名称",
+ "error": {
+ "minLength": "该字段至少需要两个字符。",
+ "invalidCharacters": "该字段只能包含字母、数字、下划线和连字符。",
+ "alreadyExists": "此摄像头已存在同名触发器。"
+ },
+ "description": "请输入用于识别此触发器的唯一名称或描述"
+ },
+ "enabled": {
+ "description": "开启/关闭此触发器"
+ },
+ "type": {
+ "title": "类型",
+ "placeholder": "选择触发类型",
+ "description": "当检测到相似的追踪目标描述时触发",
+ "thumbnail": "当检测到相似的追踪目标缩略图时触发"
+ },
+ "content": {
+ "title": "内容",
+ "imagePlaceholder": "选择图片",
+ "textPlaceholder": "输入文字内容",
+ "imageDesc": "仅显示最近的 100 张缩略图。如果找不到需要的图片,请前往“浏览”页面查看更早的目标,并从菜单中设置触发器。",
+ "textDesc": "输入文本,当检测到相似的追踪目标描述时触发此操作。",
+ "error": {
+ "required": "内容为必填项。"
+ }
+ },
+ "threshold": {
+ "title": "阈值",
+ "error": {
+ "min": "阈值必须大于 0",
+ "max": "阈值必须小于 1"
+ },
+ "desc": "设置此触发器的相似度阈值。阈值越高,触发所需的匹配就越精确。"
+ },
+ "actions": {
+ "title": "动作",
+ "desc": "默认情况下,Frigate 会为所有触发器发送 MQTT 消息。子标签会将触发器名称添加到目标标签中。属性是可搜索的元数据,独立存储在追踪目标的元数据中。",
+ "error": {
+ "min": "必须至少选择一项动作。"
+ }
+ },
+ "friendly_name": {
+ "title": "友好名称",
+ "placeholder": "为此触发器命名或添加描述",
+ "description": "(可选)为触发器添加友好名称或描述。"
+ }
+ }
+ },
+ "toast": {
+ "success": {
+ "createTrigger": "触发器 {{name}} 创建成功。",
+ "updateTrigger": "触发器 {{name}} 更新成功。",
+ "deleteTrigger": "触发器 {{name}} 已删除。"
+ },
+ "error": {
+ "createTriggerFailed": "创建触发器失败:{{errorMessage}}",
+ "updateTriggerFailed": "更新触发器失败:{{errorMessage}}",
+ "deleteTriggerFailed": "删除触发器失败:{{errorMessage}}"
+ }
+ },
+ "semanticSearch": {
+ "title": "语义搜索已关闭",
+ "desc": "必须启用语义搜索功能才能使用触发器。"
+ },
+ "wizard": {
+ "title": "创建触发器",
+ "step1": {
+ "description": "配置触发器的基础设置。"
+ },
+ "step2": {
+ "description": "设置触发此操作的内容。"
+ },
+ "step3": {
+ "description": "配置此触发器的相似度阈值与执行动作。"
+ },
+ "steps": {
+ "nameAndType": "名称与类型",
+ "configureData": "配置数据",
+ "thresholdAndActions": "阈值与动作"
+ }
+ }
+ },
+ "roles": {
+ "management": {
+ "title": "成员权限组管理",
+ "desc": "管理此 Frigate 实例的自定义权限组及其摄像头访问权限。"
+ },
+ "addRole": "添加权限组",
+ "table": {
+ "role": "权限组",
+ "cameras": "摄像头",
+ "actions": "操作",
+ "noRoles": "没有找到自定义权限组。",
+ "editCameras": "编辑摄像头",
+ "deleteRole": "删除权限组"
+ },
+ "toast": {
+ "success": {
+ "createRole": "权限组 {{role}} 创建成功",
+ "updateCameras": "已更新摄像头至 {{role}} 权限组",
+ "deleteRole": "已删除 {{role}} 权限组",
+ "userRolesUpdated_other": "已将分配到此权限组的 {{count}} 位用户更新为 “成员”,该权限组可访问所有摄像头。"
+ },
+ "error": {
+ "createRoleFailed": "创建权限组失败:{{errorMessage}}",
+ "updateCamerasFailed": "更新摄像头失败:{{errorMessage}}",
+ "deleteRoleFailed": "删除权限组失败:{{errorMessage}}",
+ "userUpdateFailed": "更新用户权限组失败:{{errorMessage}}"
+ }
+ },
+ "dialog": {
+ "createRole": {
+ "title": "创建新权限组",
+ "desc": "添加新权限组并分配摄像头访问权限。"
+ },
+ "editCameras": {
+ "title": "编辑权限组的摄像头",
+ "desc": "为权限组 {{role}} 更新摄像头访问权限。"
+ },
+ "deleteRole": {
+ "title": "删除权限组",
+ "desc": "此操作无法撤销。这将永久删除该权限组,并将所有拥有此角色的用户分配到 “成员” 权限组,该权限组将赋予用户查看所有摄像头的权限。",
+ "warn": "你确定要删除权限组 {{role}} 吗?",
+ "deleting": "删除中…"
+ },
+ "form": {
+ "role": {
+ "title": "权限组名称",
+ "placeholder": "输入权限组名称",
+ "desc": "仅允许使用字母、数字、句点和下划线。",
+ "roleIsRequired": "必须输入权限组名称",
+ "roleOnlyInclude": "权限组名称仅支持字母、数字、英文句号和下划线",
+ "roleExists": "该权限组名称已存在。"
+ },
+ "cameras": {
+ "title": "摄像头",
+ "desc": "请选择该权限组能够访问的摄像头。至少需要选择一个摄像头。",
+ "required": "至少要选择一个摄像头。"
+ }
+ }
+ }
+ },
+ "cameraWizard": {
+ "title": "添加摄像头",
+ "description": "请按照以下步骤添加摄像头至 Frigate 中。",
+ "steps": {
+ "nameAndConnection": "名称与连接",
+ "streamConfiguration": "视频流配置",
+ "validationAndTesting": "验证与测试",
+ "probeOrSnapshot": "探测或快照"
+ },
+ "save": {
+ "success": "已保存新摄像头 {{cameraName}}。",
+ "failure": "保存摄像头 {{cameraName}} 遇到了错误。"
+ },
+ "testResultLabels": {
+ "resolution": "分辨率",
+ "video": "视频",
+ "audio": "音频",
+ "fps": "帧率"
+ },
+ "commonErrors": {
+ "noUrl": "请提供正确的视频流地址",
+ "testFailed": "视频流测试失败:{{error}}"
+ },
+ "step1": {
+ "description": "请输入你的摄像头信息,并选择是自动探测摄像头信息还是手动指定品牌。",
+ "cameraName": "摄像头名称",
+ "cameraNamePlaceholder": "例如:大门,后院等",
+ "host": "主机/IP地址",
+ "port": "端口号",
+ "username": "用户名",
+ "usernamePlaceholder": "可选",
+ "password": "密码",
+ "passwordPlaceholder": "可选",
+ "selectTransport": "选择传输协议",
+ "cameraBrand": "摄像头品牌",
+ "selectBrand": "选择摄像头品牌用于生成URL地址模板",
+ "customUrl": "自定义视频流地址",
+ "brandInformation": "品牌信息",
+ "brandUrlFormat": "对于采用RTSP URL格式的摄像头,其格式为:{{exampleUrl}}",
+ "customUrlPlaceholder": "rtsp://用户名:密码@主机或IP地址:端口/路径",
+ "testConnection": "测试连接",
+ "testSuccess": "连接测试通过!",
+ "testFailed": "连接测试失败。请检查输入是否正确并重试。",
+ "streamDetails": "视频流信息",
+ "warnings": {
+ "noSnapshot": "无法从配置的视频流中获取快照。"
+ },
+ "errors": {
+ "brandOrCustomUrlRequired": "请选择摄像头品牌并配置主机/IP地址,或选择“其他”后手动配置视频流地址",
+ "nameRequired": "摄像头名称为必填项",
+ "nameLength": "摄像头名称要少于64个字符",
+ "invalidCharacters": "摄像头名称内有不允许使用的字符",
+ "nameExists": "该摄像头名称已存在",
+ "brands": {
+ "reolink-rtsp": "不建议使用萤石 RTSP 协议。建议在摄像头设置中启用 HTTP 协议,并重新运行摄像头添加向导。"
+ },
+ "customUrlRtspRequired": "自定义URL必须以“rtsp://”开头;对于非 RTSP 协议的摄像头流,需手动添加至配置文件。"
+ },
+ "docs": {
+ "reolink": "https://docs.frigate-cn.video/configuration/camera_specific.html#reolink-cameras"
+ },
+ "testing": {
+ "probingMetadata": "正在获取摄像头基本数据……",
+ "fetchingSnapshot": "正在获取摄像头快照……"
+ },
+ "connectionSettings": "连接设置",
+ "detectionMethod": "视频流检测方法",
+ "onvifPort": "ONVIF 端口",
+ "probeMode": "探测摄像头",
+ "manualMode": "手动选择",
+ "detectionMethodDescription": "如果摄像头支持 ONVIF 协议,将使用该协议探测摄像头,以自动获取摄像头视频流地址;若不支持,也可手动选择摄像头品牌来使用预设地址。如需输入自定义RTSP地址,请选择“手动选择”并选择“其他”选项。",
+ "onvifPortDescription": "对于支持ONVIF协议的摄像头,该端口通常为80或8080。",
+ "useDigestAuth": "使用摘要认证",
+ "useDigestAuthDescription": "为ONVIF协议启用HTTP摘要认证。部分摄像头可能需要专用的 ONVIF 用户名/密码,而非默认的admin账户。"
+ },
+ "step2": {
+ "description": "将根据你选择的检测方式,将会自动查找摄像头可用流配置,或进行手动配置。",
+ "streamsTitle": "摄像头视频流",
+ "addStream": "添加视频流",
+ "addAnotherStream": "添加另一个视频流",
+ "streamTitle": "{{number}} 号视频流",
+ "streamUrl": "视频流地址",
+ "streamUrlPlaceholder": "rtsp://用户名:密码@主机或IP:端口/路径",
+ "url": "URL地址",
+ "resolution": "分辨率",
+ "selectResolution": "选择分辨率",
+ "quality": "质量",
+ "selectQuality": "选择质量",
+ "roles": "功能",
+ "roleLabels": {
+ "detect": "目标/物体检测",
+ "record": "录制",
+ "audio": "音频"
+ },
+ "testStream": "测试连接",
+ "testSuccess": "连接测试通过!",
+ "testFailed": "连接测试失败,请检查输入项后重试。",
+ "testFailedTitle": "测试失败",
+ "connected": "已连接",
+ "notConnected": "未连接",
+ "featuresTitle": "特殊功能",
+ "go2rtc": "减少摄像头连接数",
+ "detectRoleWarning": "至少需要一个视频流分配\"detect\"功能才能继续。",
+ "rolesPopover": {
+ "title": "视频流功能",
+ "detect": "目标/物体的主数据流。",
+ "record": "根据配置设置保存视频流的片段。",
+ "audio": "用于音频的检测的输入流。"
+ },
+ "featuresPopover": {
+ "title": "视频流特殊功能",
+ "description": "将使用go2rtc的转流功能来减少摄像头连接数。"
+ },
+ "streamDetails": "视频流详情",
+ "probing": "正在检测摄像头中……",
+ "retry": "重试",
+ "testing": {
+ "probingMetadata": "正在查询摄像头参数……",
+ "fetchingSnapshot": "正在获取摄像头快照……"
+ },
+ "probeFailed": "检测摄像头失败:{{error}}",
+ "probingDevice": "寻找设备中……",
+ "probeSuccessful": "检测成功",
+ "probeError": "检测遇到错误",
+ "probeNoSuccess": "检测未成功",
+ "deviceInfo": "设备信息",
+ "manufacturer": "制造商",
+ "model": "型号",
+ "firmware": "固件",
+ "profiles": "配置文件",
+ "ptzSupport": "支持 PTZ",
+ "autotrackingSupport": "支持自动追踪",
+ "presets": "预设配置",
+ "rtspCandidates": "RTSP候选地址",
+ "rtspCandidatesDescription": "通过摄像头自动检测发现了以下RTSP地址。测试连接以查看视频流参数。",
+ "noRtspCandidates": "未从摄像头检测到任何 RTSP 地址。可能是你的账号密码错误,或者摄像头不支持 ONVIF 协议,亦或是当前采用的 RTSP 地址获取方式无效。请返回上一步,尝试手动输入RTSP地址。",
+ "candidateStreamTitle": "候选{{number}}",
+ "useCandidate": "使用",
+ "uriCopy": "复制",
+ "uriCopied": "地址已复制到剪贴板",
+ "testConnection": "测试连接",
+ "toggleUriView": "点击切换完整 URI 显示",
+ "errors": {
+ "hostRequired": "主机/IP地址为必填"
+ }
+ },
+ "step3": {
+ "description": "为你的摄像头配置视频流功能并添加额外视频流。",
+ "validationTitle": "视频流验证",
+ "connectAllStreams": "连接所有视频流",
+ "reconnectionSuccess": "重连成功。",
+ "reconnectionPartial": "有些视频流重连失败了。",
+ "streamUnavailable": "视频流预览不可用",
+ "reload": "重新加载",
+ "connecting": "连接中……",
+ "streamTitle": "{{number}} 号视频流",
+ "valid": "通过",
+ "failed": "失败",
+ "notTested": "未测试",
+ "connectStream": "连接",
+ "connectingStream": "连接中",
+ "disconnectStream": "断开连接",
+ "estimatedBandwidth": "预计带宽",
+ "roles": "功能",
+ "none": "无",
+ "error": "错误",
+ "streamValidated": "{{number}} 号视频流验证通过",
+ "streamValidationFailed": "{{number}} 号视频流验证失败",
+ "saveAndApply": "保存新摄像头",
+ "saveError": "配置无效,请检查你的设置。",
+ "issues": {
+ "title": "视频流验证",
+ "videoCodecGood": "视频编码为 {{codec}}。",
+ "audioCodecGood": "音频编码为 {{codec}}。",
+ "noAudioWarning": "未检测到此视频流包含音频,录制将不会有声音。",
+ "audioCodecRecordError": "录制音频需要支持AAC音频编码器。",
+ "audioCodecRequired": "需要带音频的流才能开启声音检测。",
+ "restreamingWarning": "为录制流开启减少与摄像头的连接数可能会导致 CPU 使用率略有提升。",
+ "dahua": {
+ "substreamWarning": "子码流1被锁定为低分辨率。多数大华的摄像头支持额外的子码流,但需要在摄像头设置中手动开启。如果可以,建议检查并使用这些子码流。"
+ },
+ "hikvision": {
+ "substreamWarning": "子码流1被锁定为低分辨率。多数海康威视的摄像头支持额外的子码流,但需要在摄像头设置中手动开启。如果可以,建议检查并使用这些子码流。"
+ },
+ "resolutionHigh": "使用 {{resolution}} 分辨率可能会导致占用更多的系统资源。",
+ "resolutionLow": "使用 {{resolution}} 分辨率可能过低,难以检测较小的物体。"
+ },
+ "ffmpegModule": "使用视频流兼容模式",
+ "ffmpegModuleDescription": "如果多次尝试后视频流仍无法加载,可以尝试启用此功能。启用后,Frigate 将使用集成 go2rtc 的 ffmpeg 模块,这可能会提高与某些摄像头视频流的兼容性。",
+ "streamsTitle": "摄像头视频流",
+ "addStream": "添加视频流",
+ "addAnotherStream": "添加其他视频流",
+ "streamUrl": "视频流地址",
+ "streamUrlPlaceholder": "rtsp://用户名:密码@主机:端口/路径",
+ "selectStream": "选择一个视频流",
+ "searchCandidates": "搜索候选项……",
+ "noStreamFound": "没有找到视频流",
+ "url": "URL地址",
+ "resolution": "分辨率",
+ "selectResolution": "选择分辨率",
+ "quality": "质量",
+ "selectQuality": "选择质量",
+ "roleLabels": {
+ "detect": "目标检测",
+ "record": "录制",
+ "audio": "音频检测"
+ },
+ "testStream": "测试连接",
+ "testSuccess": "视频流测试成功!",
+ "testFailed": "视频流测试失败",
+ "testFailedTitle": "测试失败",
+ "connected": "已连接",
+ "notConnected": "未连接",
+ "featuresTitle": "功能特性",
+ "go2rtc": "减少与摄像头的连接数",
+ "detectRoleWarning": "必须得有一个视频流设置了“检测”功能才能继续操作。",
+ "rolesPopover": {
+ "title": "视频流功能",
+ "detect": "用于目标检测的主码流。",
+ "record": "根据配置设置保存视频流片段。",
+ "audio": "用于音频检测的音视频流。"
+ },
+ "featuresPopover": {
+ "title": "视频流功能特性",
+ "description": "使用 go2rtc 中继转流功能,减少与摄像头的网络连接数,提升效率。"
+ }
+ },
+ "step4": {
+ "description": "将进行保存新摄像头配置前的最终验证与分析,请在保存前确保所有视频流均已连接。",
+ "validationTitle": "视频流验证",
+ "connectAllStreams": "连接所有视频流",
+ "reconnectionSuccess": "重新连接成功。",
+ "reconnectionPartial": "部分视频流重新连接失败。",
+ "streamUnavailable": "视频流预览不可用",
+ "reload": "重新加载",
+ "connecting": "连接中……",
+ "streamTitle": "视频流 {{number}}",
+ "valid": "通过",
+ "failed": "失败",
+ "notTested": "未测试",
+ "connectStream": "连接",
+ "connectingStream": "连接中",
+ "disconnectStream": "断开连接",
+ "estimatedBandwidth": "预估带宽",
+ "roles": "功能",
+ "ffmpegModule": "使用视频流兼容模式",
+ "ffmpegModuleDescription": "若多次尝试后仍无法加载视频流,可尝试启用此功能。启用后,Frigate 将通过 go2rtc 调用 ffmpeg 模块。这可能会提升与部分摄像头视频流的兼容性。",
+ "none": "无",
+ "error": "错误",
+ "streamValidated": "视频流 {{number}} 验证成功",
+ "streamValidationFailed": "视频流 {{number}} 验证失败",
+ "saveAndApply": "保存新摄像头",
+ "saveError": "配置无效,请检查您的设置。",
+ "issues": {
+ "title": "视频流验证",
+ "videoCodecGood": "视频编解码器为 {{codec}}。",
+ "audioCodecGood": "音频编解码器为 {{codec}}。",
+ "resolutionHigh": "使用 {{resolution}} 分辨率可能导致资源使用率增加。",
+ "resolutionLow": "{{resolution}} 分辨率可能过低,难以可靠检测小型目标或物体。",
+ "noAudioWarning": "检测到该视频流无音频信号,录制视频将没有声音。",
+ "audioCodecRecordError": "录制功能需要 AAC 音频编解码器以实现音频支持。",
+ "audioCodecRequired": "要实现音频检测功能,必须要有音频流。",
+ "restreamingWarning": "为录制流开启“减少与摄像头的连接数”可能会略微增加 CPU 使用率。",
+ "brands": {
+ "reolink-rtsp": "不建议使用 Reolink 的 RTSP 协议。请在摄像头后台设置中启用 HTTP协议,并重新启动向导。",
+ "reolink-http": "Reolink HTTP 视频流应该使用 FFmpeg 以获得更好的兼容性,为此视频流启用“使用流兼容模式”。"
+ },
+ "dahua": {
+ "substreamWarning": "子码流1当前被锁定为低分辨率。多数大华、安讯士、EmpireTech品牌的摄像头都支持额外的子码流,这些子码流需要在摄像头设置中手动启用。如果你的设备支持,建议你检查并使用这些高分辨率子码流。"
+ },
+ "hikvision": {
+ "substreamWarning": "子码流1当前被锁定为低分辨率。多数海康威视的摄像头都支持额外的子码流,这些子码流需要在摄像头设置中手动启用。如果你的设备支持,建议你检查并使用这些高分辨率子码流。"
+ }
+ }
+ }
+ },
+ "cameraManagement": {
+ "title": "管理摄像头",
+ "addCamera": "添加新摄像头",
+ "editCamera": "编辑摄像头:",
+ "selectCamera": "选择摄像头",
+ "backToSettings": "返回摄像头设置",
+ "streams": {
+ "title": "开启或关闭摄像头",
+ "desc": "将临时禁用摄像头,直到 Frigate 重启。禁用摄像头将完全停止 Frigate 对该摄像头视频流的处理,届时检测、录制及调试功能均不可用。
注意:go2rtc 的转流服务不受影响。"
+ },
+ "cameraConfig": {
+ "add": "添加摄像头",
+ "edit": "编辑摄像头",
+ "description": "配置摄像头设置,包括视频流输入和功能选择。",
+ "name": "摄像头名称",
+ "nameRequired": "摄像头名称为必填项",
+ "nameLength": "摄像头名称必须少于64个字符。",
+ "namePlaceholder": "例如:大门、后院等",
+ "enabled": "开启",
+ "ffmpeg": {
+ "inputs": "视频流输入",
+ "path": "视频流地址",
+ "pathRequired": "视频流地址为必填项",
+ "pathPlaceholder": "rtsp://...",
+ "roles": "功能",
+ "rolesRequired": "至少选择一个功能",
+ "rolesUnique": "每个功能(音频audio、检测detect、录制record)只能分配给一个视频流",
+ "addInput": "添加输入视频流",
+ "removeInput": "移除输入视频流",
+ "inputsRequired": "至少需要一个输入视频流"
+ },
+ "go2rtcStreams": "go2rtc 视频流",
+ "streamUrls": "视频流地址",
+ "addUrl": "添加地址",
+ "addGo2rtcStream": "添加 go2rtc 视频流",
+ "toast": {
+ "success": "摄像头 {{cameraName}} 已保存"
+ }
+ }
+ },
+ "cameraReview": {
+ "title": "摄像头核查设置",
+ "object_descriptions": {
+ "title": "生成式AI目标描述",
+ "desc": "临时启用或禁用此摄像头的 生成式AI目标描述 功能,直到 Frigate 重启。禁用后,系统将不再请求该摄像头追踪目标和物体的AI生成描述。"
+ },
+ "review_descriptions": {
+ "title": "生成式 AI 核查总结",
+ "desc": "临时开关该摄像头的 生成式 AI 核查总结 功能,直到 Frigate 重启。禁用后,系统将不再请求 AI 生成该摄像头核查项目的总结。"
+ },
+ "review": {
+ "title": "核查",
+ "desc": "临时开关该摄像头的警报与检测项生成功能,直到 Frigate 重启后恢复。禁用期间,系统将不再生成新的核查项目。 ",
+ "alerts": "警报 ",
+ "detections": "检测 "
+ },
+ "reviewClassification": {
+ "title": "核查分类",
+ "desc": "Frigate 将核查项的严重程度分为“警报”和“检测”两个等级。默认情况下,所有的人、汽车 目标都将视为警报。你可以通过修改配置文件配置区域来细分。",
+ "noDefinedZones": "此摄像头未设置任何监控区。",
+ "objectAlertsTips": "所有 {{alertsLabels}} 类目标或物体在 {{cameraName}} 下都将视为警报。",
+ "zoneObjectAlertsTips": "所有 {{alertsLabels}} 类目标或物体在 {{cameraName}} 下的 {{zone}} 区域内都将视为警报。",
+ "objectDetectionsTips": "所有在摄像头 {{cameraName}} 上,检测到的 {{detectionsLabels}} 目标或物体,无论它位于哪个区,都将显示为检测。",
+ "zoneObjectDetectionsTips": {
+ "text": "所有在摄像头 {{cameraName}} 下的 {{zone}} 区域内检测到未分类的 {{detectionsLabels}} 目标或物体,都将显示为检测。",
+ "notSelectDetections": "所有在摄像头 {{cameraName}}下的 {{zone}} 区域内检测到的 {{detectionsLabels}} 目标或物体,如果它未归类为警报,无论它位于哪个区,都将显示为检测。",
+ "regardlessOfZoneObjectDetectionsTips": "在摄像头 {{cameraName}} 上,所有未分类的 {{detectionsLabels}} 检测目标或物体,无论出现在哪个区域,都将显示为检测。"
+ },
+ "unsavedChanges": "摄像头 {{camera}} 的核查分类设置尚未保存",
+ "selectAlertsZones": "选择警报区",
+ "selectDetectionsZones": "选择检测区",
+ "limitDetections": "限制仅在特定区域内进行检测",
+ "toast": {
+ "success": "核查分类设置已保存,重启后生效。"
+ }
+ }
}
}
diff --git a/web/public/locales/zh-CN/views/system.json b/web/public/locales/zh-CN/views/system.json
index befc4bc50..4d06a16bf 100644
--- a/web/public/locales/zh-CN/views/system.json
+++ b/web/public/locales/zh-CN/views/system.json
@@ -40,16 +40,17 @@
"detector": {
"title": "检测器",
"inferenceSpeed": "检测器推理速度",
- "cpuUsage": "检测器CPU使用率",
+ "cpuUsage": "检测器 CPU 使用率",
"memoryUsage": "检测器内存使用率",
- "temperature": "检测器温度"
+ "temperature": "检测器温度",
+ "cpuUsageInformation": "此处的 CPU 使用率,只统计在给检测模型准备输入数据和处理输出数据时用到的 CPU。它不统计模型推理本身的资源占用,即使推理是在 GPU 或其他检测器上进行的。"
},
"hardwareInfo": {
"title": "硬件信息",
- "gpuUsage": "GPU使用率",
- "gpuMemory": "GPU显存",
- "gpuEncoder": "GPU编码",
- "gpuDecoder": "GPU解码",
+ "gpuUsage": "GPU 使用率",
+ "gpuMemory": "GPU 显存",
+ "gpuEncoder": "GPU 编码",
+ "gpuDecoder": "GPU 解码",
"gpuInfo": {
"vainfoOutput": {
"title": "Vainfo 输出",
@@ -65,22 +66,34 @@
"vbios": "VBios信息:{{vbios}}"
},
"closeInfo": {
- "label": "关闭GPU信息"
+ "label": "关闭 GPU 信息"
},
"copyInfo": {
- "label": "复制GPU信息"
+ "label": "复制 GPU 信息"
},
"toast": {
- "success": "已复制GPU信息到剪贴板"
+ "success": "已复制 GPU 信息到剪贴板"
}
},
"npuMemory": "NPU内存",
- "npuUsage": "NPU使用率"
+ "npuUsage": "NPU 使用率",
+ "intelGpuWarning": {
+ "title": "Intel GPU 处于警告状态",
+ "message": "GPU 状态不可用",
+ "description": "这是 Intel 的 GPU 状态报告工具(intel_gpu_top)的已知问题:该工具会失效并反复返回 GPU 使用率为 0%,即使在硬件加速和目标检测已在 (i)GPU 上正常运行的情况下也是如此,这并不是 Frigate 的 bug。你可以通过重启主机来临时修复该问题,并确认 GPU 正常工作。该问题并不会影响性能。"
+ }
},
"otherProcesses": {
"title": "其他进程",
- "processCpuUsage": "主进程CPU使用率",
- "processMemoryUsage": "主进程内存使用率"
+ "processCpuUsage": "主进程 CPU 使用率",
+ "processMemoryUsage": "主进程内存使用率",
+ "series": {
+ "go2rtc": "go2rtc",
+ "recording": "录制",
+ "review_segment": "核查片段",
+ "embeddings": "增强功能",
+ "audio_detector": "音频检测"
+ }
}
},
"storage": {
@@ -102,13 +115,17 @@
"title": "未使用",
"tips": "如果您的驱动器上存储了除 Frigate 录制内容之外的其他文件,该值可能无法准确反映 Frigate 可用的剩余空间。Frigate 不会追踪录制内容以外的存储使用情况。"
}
+ },
+ "shm": {
+ "title": "共享内存(SHM)分配",
+ "warning": "当前共享内存(SHM)容量过小( {{total}}MB),请将其至少增加到 {{min_shm}}MB。"
}
},
"cameras": {
"title": "摄像头",
"overview": "概览",
"info": {
- "cameraProbeInfo": "{{camera}} 的摄像头信息",
+ "cameraProbeInfo": "摄像头 {{camera}} 的信息",
"streamDataFromFFPROBE": "流数据信息通过ffprobe获取。",
"fetching": "正在获取摄像头数据",
"stream": "视频流{{idx}}",
@@ -158,7 +175,8 @@
"reindexingEmbeddings": "正在重新索引嵌入(已完成 {{processed}}%)",
"detectIsSlow": "{{detect}} 运行缓慢({{speed}}毫秒)",
"detectIsVerySlow": "{{detect}} 运行非常缓慢({{speed}}毫秒)",
- "cameraIsOffline": "{{camera}} 已离线"
+ "cameraIsOffline": "{{camera}} 已离线",
+ "shmTooLow": "/dev/shm 的分配空间过低(当前 {{total}} MB),应至少增加到 {{min}} MB。"
},
"enrichments": {
"title": "增强功能",
@@ -174,7 +192,17 @@
"face_recognition": "人脸特征提取",
"plate_recognition": "车牌识别",
"yolov9_plate_detection_speed": "YOLOv9 车牌检测速度",
- "yolov9_plate_detection": "YOLOv9 车牌检测"
- }
+ "yolov9_plate_detection": "YOLOv9 车牌检测",
+ "review_description": "核查总结",
+ "review_description_speed": "核查总结速度",
+ "review_description_events_per_second": "核查总结",
+ "object_description": "目标描述",
+ "object_description_speed": "目标描述速度",
+ "object_description_events_per_second": "目标描述",
+ "classification": "分类 {{name}}",
+ "classification_speed": "{{name}} 的分类速度",
+ "classification_events_per_second": "{{name}} 的每秒分类速度"
+ },
+ "averageInf": "平均推理时间"
}
}
diff --git a/web/public/locales/zh-Hant/audio.json b/web/public/locales/zh-Hant/audio.json
index bb37e6bd4..9a458ce9c 100644
--- a/web/public/locales/zh-Hant/audio.json
+++ b/web/public/locales/zh-Hant/audio.json
@@ -35,5 +35,47 @@
"vehicle": "車輛",
"animal": "動物",
"bark": "樹皮",
- "goat": "山羊"
+ "goat": "山羊",
+ "whoop": "大叫",
+ "whispering": "講話",
+ "laughter": "笑聲",
+ "snicker": "竊笑",
+ "child_singing": "小孩歌聲",
+ "synthetic_singing": "合成音樂聲",
+ "rapping": "饒舌聲",
+ "humming": "哼歌聲",
+ "groan": "呻吟聲",
+ "grunt": "咕噥聲",
+ "whistling": "口哨聲",
+ "breathing": "呼吸聲",
+ "wheeze": "喘息聲",
+ "snoring": "打呼聲",
+ "gasp": "倒抽一口氣",
+ "pant": "喘氣聲",
+ "snort": "鼻息聲",
+ "cough": "咳嗽聲",
+ "throat_clearing": "清喉嚨聲",
+ "sneeze": "打噴嚏聲",
+ "sniff": "嗅聞聲",
+ "run": "跑步聲",
+ "shuffle": "拖著腳走路聲",
+ "footsteps": "腳步聲",
+ "chewing": "咀嚼聲",
+ "biting": "咬",
+ "gargling": "漱口",
+ "stomach_rumble": "腸胃蠕動",
+ "burping": "打嗝",
+ "hiccup": "打噎",
+ "fart": "放屁",
+ "hands": "手",
+ "finger_snapping": "彈手指聲",
+ "clapping": "拍手",
+ "heartbeat": "心跳聲",
+ "heart_murmur": "心臟雜音",
+ "cheering": "歡呼聲",
+ "applause": "掌聲",
+ "chatter": "嘈雜聲",
+ "crowd": "人群聲",
+ "children_playing": "兒童嬉鬧聲",
+ "pets": "寵物"
}
diff --git a/web/public/locales/zh-Hant/common.json b/web/public/locales/zh-Hant/common.json
index acc7a0a08..17a60efaa 100644
--- a/web/public/locales/zh-Hant/common.json
+++ b/web/public/locales/zh-Hant/common.json
@@ -39,8 +39,8 @@
"24hour": "M 月 d 日 HH:mm:ss"
},
"formattedTimestamp2": {
- "12hour": "MM 月 dd 日 ah:mm:ss",
- "24hour": "MM 月 dd 日 HH:mm:ss"
+ "12hour": "MM/dd h:mm:ssa",
+ "24hour": "d MMM HH:mm:ss"
},
"formattedTimestampHourMinute": {
"12hour": "a h:mm",
@@ -64,9 +64,12 @@
},
"formattedTimestampMonthDay": "M 月 d 日",
"formattedTimestampFilename": {
- "12hour": "yy年MM月dd日 ah時mm分ss秒",
+ "12hour": "yy年MM月dd日 h時mm分ss秒",
"24hour": "yy年MM月dd日 HH時mm分ss秒"
- }
+ },
+ "inProgress": "處理中",
+ "invalidStartTime": "無效的起始時間",
+ "invalidEndTime": "無效的結束時間"
},
"unit": {
"speed": {
@@ -76,10 +79,23 @@
"length": {
"feet": "英尺",
"meters": "公尺"
+ },
+ "data": {
+ "kbps": "kB/s",
+ "mbps": "MB/s",
+ "gbps": "GB/s",
+ "kbph": "kB/小時",
+ "mbph": "MB/小時",
+ "gbph": "GB/小時"
}
},
"label": {
- "back": "返回"
+ "back": "返回",
+ "hide": "隱藏{{item}}",
+ "show": "顯示{{item}}",
+ "ID": "ID",
+ "none": "無",
+ "all": "全部"
},
"button": {
"apply": "套用",
@@ -89,8 +105,8 @@
"enable": "啟用",
"disabled": "已停用",
"disable": "停用",
- "save": "保存",
- "saving": "保存中…",
+ "save": "儲存",
+ "saving": "儲存中…",
"cancel": "取消",
"close": "關閉",
"copy": "複製",
@@ -116,7 +132,8 @@
"unselect": "取消選取",
"export": "匯出",
"deleteNow": "立即刪除",
- "next": "繼續"
+ "next": "繼續",
+ "continue": "繼續"
},
"menu": {
"system": "系統",
@@ -160,7 +177,15 @@
"ca": "Català (加泰隆尼亞文)",
"withSystem": {
"label": "使用系統語言設定"
- }
+ },
+ "ptBR": "Português brasileiro (巴西葡萄牙文)",
+ "sr": "Српски (塞爾維亞文)",
+ "sl": "Slovenščina (斯洛文尼亞文)",
+ "lt": "Lietuvių (立陶宛文)",
+ "bg": "Български (保加利亞文)",
+ "gl": "Galego (加利西亞文)",
+ "id": "Bahasa Indonesia (印尼文)",
+ "ur": "اردو (烏爾都文)"
},
"appearance": "外觀",
"darkMode": {
@@ -207,7 +232,8 @@
"anonymous": "匿名",
"logout": "登出",
"setPassword": "設定密碼"
- }
+ },
+ "classification": "標籤分類"
},
"toast": {
"copyUrlToClipboard": "已複製連結至剪貼簿。",
@@ -247,5 +273,18 @@
"title": "404",
"desc": "找不到頁面"
},
- "selectItem": "選擇 {{item}}"
+ "selectItem": "選擇 {{item}}",
+ "readTheDocumentation": "閱讀文件",
+ "list": {
+ "two": "{{0}}和{{1}}",
+ "many": "{{items}}和{{last}}",
+ "separatorWithSpace": ", "
+ },
+ "field": {
+ "optional": "可選的",
+ "internalID": "在Frigate 設定檔和資料庫使用的內部ID"
+ },
+ "information": {
+ "pixels": "{{area}}px"
+ }
}
diff --git a/web/public/locales/zh-Hant/components/auth.json b/web/public/locales/zh-Hant/components/auth.json
index 34b97ef78..fbc70c4d4 100644
--- a/web/public/locales/zh-Hant/components/auth.json
+++ b/web/public/locales/zh-Hant/components/auth.json
@@ -10,6 +10,7 @@
"rateLimit": "超過次數限制,請稍後再試。",
"loginFailed": "登入失敗",
"unknownError": "未知錯誤,請檢查日誌。"
- }
+ },
+ "firstTimeLogin": "首次嘗試登入嗎?請從 Frigate 的日誌中查找產生的登入密碼等相關資訊。"
}
}
diff --git a/web/public/locales/zh-Hant/components/camera.json b/web/public/locales/zh-Hant/components/camera.json
index d07662c7e..3bace4d9d 100644
--- a/web/public/locales/zh-Hant/components/camera.json
+++ b/web/public/locales/zh-Hant/components/camera.json
@@ -66,7 +66,8 @@
"label": "相容模式",
"desc": "只有在鏡頭的串流影像中出現色彩異常及右側有斜線時才啟用此選項。"
}
- }
+ },
+ "birdseye": "鳥瞰"
}
},
"debug": {
diff --git a/web/public/locales/zh-Hant/components/dialog.json b/web/public/locales/zh-Hant/components/dialog.json
index a29b487e1..b28ccca48 100644
--- a/web/public/locales/zh-Hant/components/dialog.json
+++ b/web/public/locales/zh-Hant/components/dialog.json
@@ -51,12 +51,13 @@
"export": "匯出",
"selectOrExport": "選擇或匯出",
"toast": {
- "success": "成功開始匯出。請至 /exports 資料夾查看匯出資料。",
+ "success": "成功開始匯出。至 /exports 頁查看匯出資料。",
"error": {
"failed": "匯出失敗:{{error}}",
"endTimeMustAfterStartTime": "結束時間必須要在開始時間之後",
"noVaildTimeSelected": "沒有選取有效的時間範圍"
- }
+ },
+ "view": "查看"
},
"fromTimeline": {
"saveExport": "保存匯出資料",
@@ -80,7 +81,7 @@
},
"search": {
"saveSearch": {
- "label": "保存搜尋",
+ "label": "儲存搜尋",
"desc": "替此保存的搜尋命名。",
"placeholder": "請輸入搜尋的名稱",
"overwrite": "{{searchName}} 已存在。保存將會覆蓋現有資料。",
@@ -106,7 +107,16 @@
"button": {
"export": "匯出",
"markAsReviewed": "標記為已審核",
- "deleteNow": "立即刪除"
+ "deleteNow": "立即刪除",
+ "markAsUnreviewed": "標記為未審核"
}
+ },
+ "imagePicker": {
+ "selectImage": "選取追蹤物件預覽圖",
+ "unknownLabel": "已儲存觸發圖片",
+ "search": {
+ "placeholder": "以標籤或子標籤搜尋..."
+ },
+ "noImages": "未找到此攝影機的縮圖"
}
}
diff --git a/web/public/locales/zh-Hant/components/filter.json b/web/public/locales/zh-Hant/components/filter.json
index a1192ac59..1cbef2fd3 100644
--- a/web/public/locales/zh-Hant/components/filter.json
+++ b/web/public/locales/zh-Hant/components/filter.json
@@ -121,6 +121,20 @@
"loading": "讀取已辨識車牌中…",
"placeholder": "輸入以搜尋車牌…",
"noLicensePlatesFound": "未找到車牌。",
- "selectPlatesFromList": "從列表中選擇一個或多個車牌。"
+ "selectPlatesFromList": "從列表中選擇一個或多個車牌。",
+ "selectAll": "全選",
+ "clearAll": "全部清除"
+ },
+ "classes": {
+ "label": "類別",
+ "all": {
+ "title": "所有類別"
+ },
+ "count_one": "{{count}} 個類別",
+ "count_other": "{{count}} 個類別"
+ },
+ "attributes": {
+ "label": "分類屬性",
+ "all": "所有屬性"
}
}
diff --git a/web/public/locales/zh-Hant/components/input.json b/web/public/locales/zh-Hant/components/input.json
index df3ed93c0..ed7eee77c 100644
--- a/web/public/locales/zh-Hant/components/input.json
+++ b/web/public/locales/zh-Hant/components/input.json
@@ -3,7 +3,7 @@
"downloadVideo": {
"label": "下載影片",
"toast": {
- "success": "你的審查影片已開始下載。"
+ "success": "你的審查項目影片已開始下載。"
}
}
}
diff --git a/web/public/locales/zh-Hant/views/classificationModel.json b/web/public/locales/zh-Hant/views/classificationModel.json
new file mode 100644
index 000000000..06aabdf5c
--- /dev/null
+++ b/web/public/locales/zh-Hant/views/classificationModel.json
@@ -0,0 +1,117 @@
+{
+ "toast": {
+ "success": {
+ "deletedImage": "已刪除的圖片",
+ "deletedModel_other": "已成功刪除 {{count}} 個模型",
+ "deletedCategory": "已刪除分類",
+ "categorizedImage": "成功分類圖片",
+ "trainedModel": "訓練模型成功。",
+ "trainingModel": "已開始模型訓練。",
+ "updatedModel": "已更新模型配置",
+ "renamedCategory": "成功修改分類名稱為{{name}}"
+ },
+ "error": {
+ "deleteImageFailed": "刪除失敗:{{errorMessage}}",
+ "deleteCategoryFailed": "刪除分類標籤失敗: {{errorMessage}}",
+ "deleteModelFailed": "刪除模型失敗: {{errorMessage}}",
+ "categorizeFailed": "圖片分類失敗: {{errorMessage}}",
+ "trainingFailed": "模型訓練失敗。請至Frigate 日誌查看詳情。",
+ "trainingFailedToStart": "模型訓練啟動失敗: {{errorMessage}}",
+ "updateModelFailed": "模型更新失敗: {{errorMessage}}",
+ "renameCategoryFailed": "類別重新命名失敗: {{errorMessage}}"
+ }
+ },
+ "documentTitle": "分類模型",
+ "details": {
+ "scoreInfo": "分數表示該目標所有偵測結果的平均分類置信度。",
+ "none": "沒有",
+ "unknown": "未知"
+ },
+ "button": {
+ "deleteClassificationAttempts": "刪除分類圖片",
+ "renameCategory": "重新命名分類",
+ "deleteCategory": "刪除分類",
+ "deleteImages": "刪除圖片",
+ "trainModel": "訓練模型",
+ "addClassification": "添加分類",
+ "deleteModels": "刪除模型",
+ "editModel": "編輯模型"
+ },
+ "tooltip": {
+ "trainingInProgress": "模型正在訓練中",
+ "noNewImages": "沒有新的圖片可用於訓練。請先對數據集中的更多圖片進行分類。",
+ "noChanges": "自上次訓練以來,數據集未作任何更改。",
+ "modelNotReady": "模型尚未準備好進行訓練"
+ },
+ "deleteCategory": {
+ "title": "刪除類別",
+ "desc": "你確定要刪除類別{{name}}嗎? 這將刪除所有有關的圖片並需要重新訓練模型。",
+ "minClassesTitle": "無法刪除此類別",
+ "minClassesDesc": "分類模型必須至少擁有2個類別,新增一個新的類別已刪除這個。"
+ },
+ "deleteModel": {
+ "title": "刪除分類模型",
+ "single": "你確定要刪除{{name}}嗎? 這將永久刪除包含圖片和訓練資料在內的所有相關資料。這個操作無法被復原。",
+ "desc_other": "你確定要刪除{{count}}個模型? 這將永久刪除包含圖片和訓練資料在內的所有相關資料。這個操作無法被復原。"
+ },
+ "edit": {
+ "title": "編輯分類模型",
+ "descriptionState": "編輯這個狀態分類模型的類別,變更將需要重新訓練模型。",
+ "descriptionObject": "編輯這個物件分類模型的物件種類與分類種類。",
+ "stateClassesInfo": "注意: 變更狀態類別後需要以更新後的類別重新訓練模型。"
+ },
+ "deleteDatasetImages": {
+ "title": "刪除圖片資料集合",
+ "desc_other": "你確定要從{{dataset}}中刪除{{count}}個圖片嗎? 這個操作將無法被復原且將需要重新訓練模型。"
+ },
+ "deleteTrainImages": {
+ "title": "刪除訓練圖片",
+ "desc_other": "你確定要刪除{{count}}個圖片? 這個操作無法被復原。"
+ },
+ "renameCategory": {
+ "title": "重新命名類別",
+ "desc": "輸入 {{name}} 的新名稱。您需要在名稱變更後重新訓練模型以套用變更。"
+ },
+ "description": {
+ "invalidName": "無效的名稱。名稱只能包涵英數字、空格、撇(')、底線(_)及連字號(-)。"
+ },
+ "train": {
+ "title": "最近的分類紀錄",
+ "titleShort": "最近",
+ "aria": "選取最近的分類紀錄"
+ },
+ "categories": "類別",
+ "createCategory": {
+ "new": "建立新的類別"
+ },
+ "wizard": {
+ "step1": {
+ "objectLabel": "物件標籤",
+ "objectLabelPlaceholder": "請選擇物件類型...",
+ "classificationType": "分類類型",
+ "classificationTypeTip": "學習更多有關分類類型",
+ "description": "狀態模型監視固定攝像頭區域的變化(例如:開關門)。物件模型為檢測到的物件(例如:已知動物、送貨員等等)添加分類。",
+ "name": "名稱",
+ "namePlaceholder": "請輸入模型名稱...",
+ "type": "類別",
+ "typeState": "狀態",
+ "typeObject": "物件"
+ },
+ "steps": {
+ "chooseExamples": "選擇範本"
+ }
+ },
+ "menu": {
+ "states": "狀態"
+ },
+ "noModels": {
+ "object": {
+ "title": "沒有物件檢測模型",
+ "description": "建立自訂模型以對偵測到的物件進行分類。",
+ "buttonText": "建立物件模型"
+ },
+ "state": {
+ "description": "建立自訂模型,用於監控和分類特定攝影機區域的狀態變化。"
+ }
+ }
+}
diff --git a/web/public/locales/zh-Hant/views/configEditor.json b/web/public/locales/zh-Hant/views/configEditor.json
index 3788bace0..f1943edbb 100644
--- a/web/public/locales/zh-Hant/views/configEditor.json
+++ b/web/public/locales/zh-Hant/views/configEditor.json
@@ -12,5 +12,7 @@
}
},
"saveOnly": "僅保存",
- "confirm": "是否不保存就離開?"
+ "confirm": "是否不保存就離開?",
+ "safeConfigEditor": "設定編輯器(安全模式)",
+ "safeModeDescription": "由於設定驗證有誤,Frigate 進入安全模式。"
}
diff --git a/web/public/locales/zh-Hant/views/events.json b/web/public/locales/zh-Hant/views/events.json
index 8f840aab1..7d5b4d28c 100644
--- a/web/public/locales/zh-Hant/views/events.json
+++ b/web/public/locales/zh-Hant/views/events.json
@@ -8,7 +8,11 @@
"empty": {
"motion": "未找到移動資料",
"alert": "沒有警告需要審核",
- "detection": "沒有偵測到的內容需要審核"
+ "detection": "沒有偵測到的內容需要審核",
+ "recordingsDisabled": {
+ "title": "必須啟用錄製功能",
+ "description": "僅當該攝影機啟用錄製功能時,才能為該攝影機建立審查項目。"
+ }
},
"timeline": "時間線",
"timeline.aria": "選擇時間線",
@@ -34,5 +38,30 @@
"selected_one": "已選擇 {{count}} 個",
"selected_other": "已選擇 {{count}} 個",
"camera": "鏡頭",
- "detected": "已偵測"
+ "detected": "已偵測",
+ "suspiciousActivity": "可疑的活動",
+ "threateningActivity": "有威脅性的活動",
+ "zoomIn": "放大",
+ "zoomOut": "縮小",
+ "detail": {
+ "label": "詳細資訊",
+ "noDataFound": "沒有可供檢視的詳細資訊",
+ "aria": "開關詳細資訊視圖",
+ "trackedObject_one": "{{count}} 個物件",
+ "trackedObject_other": "{{count}} 個物件",
+ "noObjectDetailData": "沒有可用物件細節。",
+ "settings": "細節視圖設定",
+ "alwaysExpandActive": {
+ "title": "總是展開",
+ "desc": "在可用時總是展開當前物件的詳細資訊。"
+ }
+ },
+ "objectTrack": {
+ "trackedPoint": "追蹤點",
+ "clickToSeek": "點擊從此時間點尋找"
+ },
+ "normalActivity": "正常",
+ "needsReview": "待審核",
+ "securityConcern": "安全隱憂",
+ "select_all": "全選"
}
diff --git a/web/public/locales/zh-Hant/views/explore.json b/web/public/locales/zh-Hant/views/explore.json
index 6997b08dd..598700963 100644
--- a/web/public/locales/zh-Hant/views/explore.json
+++ b/web/public/locales/zh-Hant/views/explore.json
@@ -47,12 +47,16 @@
"success": {
"regenerate": "已從 {{provider}} 請求新的說明。根據提供者的速度,生成新的說明可能會需要一段時間。",
"updatedSublabel": "成功更新子標籤。",
- "updatedLPR": "成功更新車牌。"
+ "updatedLPR": "成功更新車牌。",
+ "updatedAttributes": "已成功更新屬性。",
+ "audioTranscription": "已成功送出音訊轉錄請求。轉錄完成所需時間會依您的 Frigate 伺服器速度而定,可能需要一段時間。"
},
"error": {
"regenerate": "請求 {{provider}} 生成新的說明失敗:{{errorMessage}}",
"updatedSublabelFailed": "更新子標籤失敗:{{errorMessage}}",
- "updatedLPRFailed": "更新車牌失敗:{{errorMessage}}"
+ "updatedLPRFailed": "更新車牌失敗:{{errorMessage}}",
+ "updatedAttributesFailed": "更新屬性失敗:{{errorMessage}}",
+ "audioTranscription": "請求音訊轉錄失敗:{{errorMessage}}"
}
}
},
@@ -97,6 +101,17 @@
"tips": {
"descriptionSaved": "成功保存說明",
"saveDescriptionFailed": "更新說明失敗:{{errorMessage}}"
+ },
+ "editAttributes": {
+ "title": "編輯屬性",
+ "desc": "為此 {{label}} 選擇分類屬性"
+ },
+ "score": {
+ "label": "分數"
+ },
+ "attributes": "分類屬性",
+ "title": {
+ "label": "標題"
}
},
"trackedObjectDetails": "追蹤物件詳情",
@@ -104,7 +119,9 @@
"details": "詳情",
"snapshot": "截圖",
"video": "影片",
- "object_lifecycle": "物件生命週期"
+ "object_lifecycle": "物件生命週期",
+ "thumbnail": "預覽圖",
+ "tracking_details": "追蹤詳情"
},
"objectLifecycle": {
"title": "物件生命週期",
@@ -182,12 +199,34 @@
},
"deleteTrackedObject": {
"label": "刪除此追蹤物件"
+ },
+ "hideObjectDetails": {
+ "label": "隱藏物件路徑"
+ },
+ "showObjectDetails": {
+ "label": "顯示物件路徑"
+ },
+ "addTrigger": {
+ "label": "新增觸發器",
+ "aria": "為此追蹤物件新增觸發器"
+ },
+ "audioTranscription": {
+ "label": "轉錄",
+ "aria": "請求音訊轉錄"
+ },
+ "downloadCleanSnapshot": {
+ "label": "下載乾淨的快照",
+ "aria": "下載乾淨的快照"
+ },
+ "viewTrackingDetails": {
+ "label": "檢視追蹤詳細資訊",
+ "aria": "顯示追蹤詳細資訊"
}
},
"dialog": {
"confirmDelete": {
"title": "確認刪除",
- "desc": "刪除此追蹤物件將移除截圖、所有已保存的嵌入,以及所有相關的物件生命週期紀錄。歷史記錄中的錄影不會被刪除。
你確定要刪除嗎?"
+ "desc": "刪除此追蹤物件將移除截圖、所有已保存的嵌入,以及所有相關的追蹤詳情。歷史記錄中的錄影不會被刪除。
你確定要刪除嗎?"
}
},
"noTrackedObjects": "找不到追蹤物件",
@@ -200,6 +239,60 @@
"success": "成功刪除蹤物件。",
"error": "刪除追蹤物件失敗:{{errorMessage}}"
}
+ },
+ "previousTrackedObject": "上一個追蹤物件",
+ "nextTrackedObject": "下一個追蹤物件"
+ },
+ "trackingDetails": {
+ "title": "追蹤詳情",
+ "noImageFound": "沒有找到在此時間點的圖片。",
+ "createObjectMask": "建立物件遮罩",
+ "adjustAnnotationSettings": "調整標記設定",
+ "scrollViewTips": "點擊查看物件周期的關鍵時間。",
+ "autoTrackingTips": "自動追蹤鏡頭的邊框位置可能不準確。",
+ "count": "{{second}}之{{first}}",
+ "trackedPoint": "追蹤點",
+ "lifecycleItemDesc": {
+ "visible": "偵測到 {{label}}",
+ "entered_zone": "{{label}} 已進入 {{zones}}",
+ "active": "{{label}} 正在活動",
+ "stationary": "{{label}} 變為靜止",
+ "attribute": {
+ "faceOrLicense_plate": "偵測到{{label}} {{attribute}}",
+ "other": "{{label}} 被識別為 {{attribute}}"
+ },
+ "gone": "{{label}} 已離開",
+ "heard": "聽到了 {{label}}",
+ "external": "偵測到 {{label}}",
+ "header": {
+ "zones": "區域",
+ "ratio": "比例",
+ "score": "分數",
+ "area": "面積"
+ }
+ },
+ "annotationSettings": {
+ "title": "標記設定",
+ "showAllZones": {
+ "title": "顯示所有區域",
+ "desc": "總是在物件進入區域時在畫面上顯示區域範圍。"
+ },
+ "offset": {
+ "label": "標記偏移量",
+ "desc": "這個資料來自您的鏡頭的偵測串流源,但是被疊加在錄影串流源的畫面上,兩個串流源不太可能完美的同步,因此邊框與畫面無法完美的對齊。您可以用這項設定調整標記在時間上前後偏移的補償量來更好的將其與錄影畫面對齊。",
+ "millisecondsToOffset": "偵測標記偏移補償的毫秒數。預設值: 0",
+ "tips": "如果影片播放進度超前於方框和路徑點,則降低該值;如果影片播放進度落後於方框和路徑點,則增加該數值。該值可以為負數。",
+ "toast": {
+ "success": "{{camera}} 的標記偏移補償量已儲存至設定檔。"
+ }
+ }
+ },
+ "carousel": {
+ "previous": "上一張投影片",
+ "next": "下一張投影片"
}
+ },
+ "aiAnalysis": {
+ "title": "AI 分析"
}
}
diff --git a/web/public/locales/zh-Hant/views/exports.json b/web/public/locales/zh-Hant/views/exports.json
index 159e66e17..3d3f9e87c 100644
--- a/web/public/locales/zh-Hant/views/exports.json
+++ b/web/public/locales/zh-Hant/views/exports.json
@@ -13,5 +13,11 @@
"renameExportFailed": "重新命名匯出內容失敗:{{errorMessage}}"
}
},
- "deleteExport.desc": "你確定要刪除 {{exportName}} 嗎?"
+ "deleteExport.desc": "你確定要刪除 {{exportName}} 嗎?",
+ "tooltip": {
+ "shareExport": "分享匯出",
+ "downloadVideo": "下載影片",
+ "editName": "編輯名稱",
+ "deleteExport": "刪除匯出"
+ }
}
diff --git a/web/public/locales/zh-Hant/views/faceLibrary.json b/web/public/locales/zh-Hant/views/faceLibrary.json
index 52675a51b..938bf1581 100644
--- a/web/public/locales/zh-Hant/views/faceLibrary.json
+++ b/web/public/locales/zh-Hant/views/faceLibrary.json
@@ -1,6 +1,6 @@
{
"description": {
- "addFace": "了解如何新增圖片集合至人臉資料庫。",
+ "addFace": "上傳您的第一張照片至臉部資料庫以新增一個新的集合。",
"placeholder": "輸入此集合的名稱",
"invalidName": "無效的名稱。名稱只能包涵英數字、空格、撇(')、底線(_)及連字號(-)。"
},
@@ -24,7 +24,7 @@
"title": "建立集合",
"desc": "建立新集合",
"new": "建立新人臉",
- "nextSteps": "為了建立可靠的模型基底:在訓練分頁中選擇並針對每個偵測到人的圖片進行訓練。 請優先使用正臉照以獲得最佳效果,請盡量避免使用從側面或有傾斜角度的人臉 "
+ "nextSteps": "為了建立可靠的模型基底:在最近的識別紀錄分頁中選擇並針對每個偵測到人的圖片進行訓練。 請優先使用正臉照以獲得最佳效果,請盡量避免使用從側面或有傾斜角度的人臉 "
},
"steps": {
"faceName": "輸入人臉名稱",
@@ -35,9 +35,10 @@
}
},
"train": {
- "title": "訓練",
- "aria": "選擇訓練",
- "empty": "最近沒有辨識人臉的操作"
+ "title": "最近的識別紀錄",
+ "aria": "選擇最近的識別紀錄",
+ "empty": "最近沒有辨識人臉的操作",
+ "titleShort": "最近"
},
"selectFace": "選擇人臉",
"deleteFaceLibrary": {
@@ -65,7 +66,7 @@
"selectImage": "請選擇一個圖片檔。"
},
"dropActive": "將圖片拖到這裡…",
- "dropInstructions": "將圖片拖放至此處,或點擊以選取",
+ "dropInstructions": "拖放或貼上圖片至此處,或點擊以選取",
"maxSize": "最大檔案大小:{{size}}MB"
},
"nofaces": "沒有可用的人臉",
@@ -81,7 +82,7 @@
"deletedName_other": "{{count}} 個人臉已成功刪除。",
"renamedFace": "成功將人臉重新命名為 {{name}}",
"trainedFace": "成功訓練人臉。",
- "updatedFaceScore": "成功更新人臉分數。"
+ "updatedFaceScore": "成功更新人臉分數{{name}}({{score}})。"
},
"error": {
"uploadingImageFailed": "上傳圖片失敗:{{errorMessage}}",
diff --git a/web/public/locales/zh-Hant/views/live.json b/web/public/locales/zh-Hant/views/live.json
index 55947b9f2..a839b4b88 100644
--- a/web/public/locales/zh-Hant/views/live.json
+++ b/web/public/locales/zh-Hant/views/live.json
@@ -39,7 +39,15 @@
"label": "點擊畫面以置中 PTZ 鏡頭"
}
},
- "presets": "PTZ 鏡頭預設"
+ "presets": "PTZ 鏡頭預設",
+ "focus": {
+ "in": {
+ "label": "聚焦 PTZ 鏡頭"
+ },
+ "out": {
+ "label": "離焦 PTZ 鏡頭"
+ }
+ }
},
"cameraAudio": {
"enable": "啟用鏡頭音訊",
@@ -78,8 +86,8 @@
"disable": "隱藏串流統計資料"
},
"manualRecording": {
- "title": "應需錄影",
- "tips": "根據此鏡頭的錄影保留設定手動啟動事件。",
+ "title": "應需",
+ "tips": "根據此鏡頭的錄影保留設定,下載快照或手動啟動事件。",
"playInBackground": {
"label": "背景播放",
"desc": "啟用此選項以在播放器被隱藏時繼續播放串流。"
@@ -154,5 +162,15 @@
"label": "編輯鏡頭群組"
},
"exitEdit": "結束編輯"
+ },
+ "transcription": {
+ "enable": "啟用即時語音轉錄",
+ "disable": "停用即時語音轉錄"
+ },
+ "snapshot": {
+ "takeSnapshot": "下載即時快照",
+ "noVideoSource": "沒有可用的影片資源以擷取快照。",
+ "captureFailed": "快照擷取失敗。",
+ "downloadStarted": "已開始下載快照。"
}
}
diff --git a/web/public/locales/zh-Hant/views/search.json b/web/public/locales/zh-Hant/views/search.json
index 0b56209c2..7fe475e5e 100644
--- a/web/public/locales/zh-Hant/views/search.json
+++ b/web/public/locales/zh-Hant/views/search.json
@@ -5,7 +5,7 @@
"button": {
"clear": "清空搜尋",
"filterActive": "過濾中",
- "save": "保存搜尋",
+ "save": "儲存搜尋",
"delete": "刪除保存的搜尋",
"filterInformation": "過濾資訊"
},
@@ -26,7 +26,8 @@
"recognized_license_plate": "已辨識的車牌",
"has_clip": "包含片段",
"has_snapshot": "包含截圖",
- "time_range": "時間範圍"
+ "time_range": "時間範圍",
+ "attributes": "屬性"
},
"searchType": {
"thumbnail": "截圖",
diff --git a/web/public/locales/zh-Hant/views/settings.json b/web/public/locales/zh-Hant/views/settings.json
index d252250e9..97829f536 100644
--- a/web/public/locales/zh-Hant/views/settings.json
+++ b/web/public/locales/zh-Hant/views/settings.json
@@ -3,13 +3,15 @@
"default": "設定 - Frigate",
"authentication": "認證設定 - Frigate",
"camera": "鏡頭設定 - Frigate",
- "enrichments": "進階設定 - Frigate",
- "general": "一般設定 - Frigate",
+ "enrichments": "進階功能設定 - Frigate",
+ "general": "使用者介面設定 - Frigate",
"frigatePlus": "Frigate+ 設定 - Frigate",
"notifications": "通知設定 - Frigate",
"masksAndZones": "遮罩與區域編輯器 - Frigate",
"motionTuner": "移動偵測調教器 - Frigate",
- "object": "除錯 - Frigate"
+ "object": "除錯 - Frigate",
+ "cameraManagement": "管理鏡頭 - Frigate",
+ "cameraReview": "相機預覽設置 - Frigate"
},
"menu": {
"ui": "使用者介面",
@@ -20,7 +22,11 @@
"debug": "除錯",
"users": "使用者",
"notifications": "通知",
- "frigateplus": "Frigate+"
+ "frigateplus": "Frigate+",
+ "triggers": "觸發",
+ "cameraManagement": "管理",
+ "cameraReview": "預覽",
+ "roles": "角色"
},
"dialog": {
"unsavedChanges": {
@@ -33,12 +39,117 @@
"noCamera": "沒有鏡頭"
},
"general": {
- "title": "一般設定",
+ "title": "使用者介面設定",
"liveDashboard": {
"title": "即時監控面板",
"automaticLiveView": {
"label": "自動即時檢視",
"desc": "在偵測到移動時自動切換至即時影像。停用此設定將使得在即時監控面板上的靜態畫面每分鐘更新一次。"
+ },
+ "playAlertVideos": {
+ "label": "播放警報影片",
+ "desc": "最近的警報影片預設會在即時監控面板中連續循環播放。取消這個選項,可以只顯示靜態的最近警報擷圖(僅套用於該裝置/瀏覽器)。"
+ },
+ "displayCameraNames": {
+ "label": "總是顯示鏡頭名稱",
+ "desc": "總是在多鏡頭直播頁面顯示鏡頭的名稱標籤。"
+ },
+ "liveFallbackTimeout": {
+ "label": "直播播放器回退逾時",
+ "desc": "當高畫質串流直播無法使用時,在此秒數後會回退成低流量模式。預設值: 3。"
+ }
+ },
+ "storedLayouts": {
+ "title": "儲存的排版",
+ "desc": "在鏡頭群組內的鏡頭排版可以拖拉或縮放調整。這個排版設定儲存於目前瀏覽器的本機儲存空間。",
+ "clearAll": "清除所有排版"
+ },
+ "cameraGroupStreaming": {
+ "title": "鏡頭群組串流播放設定",
+ "desc": "每個鏡頭群組的串流播放設定都儲存在目前瀏覽器的本機儲存空間。",
+ "clearAll": "清除所有串流播放設定"
+ },
+ "recordingsViewer": {
+ "title": "錄影檢視器",
+ "defaultPlaybackRate": {
+ "label": "預設播放速度",
+ "desc": "錄影回放的預設播放速度。"
+ }
+ },
+ "calendar": {
+ "title": "月曆",
+ "firstWeekday": {
+ "label": "第一個工作天",
+ "desc": "在檢視月曆中,每個禮拜從禮拜幾開始。",
+ "sunday": "禮拜天",
+ "monday": "禮拜一"
+ }
+ },
+ "toast": {
+ "success": {
+ "clearStoredLayout": "清除 {{cameraName}} 儲存的排版",
+ "clearStreamingSettings": "清除所有鏡頭群組的串流播放設定。"
+ },
+ "error": {
+ "clearStoredLayoutFailed": "清除儲存的排版設定失敗: {{errorMessage}}",
+ "clearStreamingSettingsFailed": "清除串流播放設定失敗: {{errorMessage}}"
+ }
+ }
+ },
+ "enrichments": {
+ "title": "進階功能設定",
+ "unsavedChanges": "尚未儲存的強化設定變更",
+ "semanticSearch": {
+ "modelSize": {
+ "label": "模型大小",
+ "small": {
+ "title": "小"
+ }
+ },
+ "title": "語意搜尋",
+ "desc": "Frigate 中的語意搜尋功能可讓您使用圖像本身、使用者定義的文字描述或自動產生的描述,在審核專案中尋找追蹤物件。",
+ "reindexNow": {
+ "label": "立即重新索引",
+ "desc": "重新索引會為所有追蹤物件重新產生嵌入向量。此過程在背景運行,可能會佔用大量 CPU 資源,並且耗時較長,具體取決於追蹤物件的數量。"
+ }
+ },
+ "faceRecognition": {
+ "title": "人臉識別"
+ },
+ "birdClassification": {
+ "title": "鳥類分類",
+ "desc": "鳥類分類功能使用量化的 TensorFlow 模型識別已知鳥類。識別出已知鳥類後,其通用名稱將作為子標籤添加。此資訊會顯示在使用者介面、篩選器以及通知中。"
+ }
+ },
+ "cameraWizard": {
+ "title": "新增相機",
+ "testResultLabels": {
+ "resolution": "解析度",
+ "video": "影像",
+ "audio": "語音"
+ },
+ "commonErrors": {
+ "testFailed": "串流測試失敗: {{error}}"
+ },
+ "step1": {
+ "description": "輸入相機詳細資訊並選擇自動偵測或手動選擇相機品牌。",
+ "cameraName": "相機名稱",
+ "cameraNamePlaceholder": "例: 前門 / 後院",
+ "host": "主機/IP 位置",
+ "port": "埠",
+ "username": "用戶名稱",
+ "usernamePlaceholder": "選填",
+ "password": "密碼",
+ "passwordPlaceholder": "選填",
+ "selectTransport": "選擇協議",
+ "cameraBrand": "相機品牌"
+ }
+ },
+ "triggers": {
+ "toast": {
+ "error": {
+ "deleteTriggerFailed": "刪除觸發器失敗:{{errorMessage}}",
+ "updateTriggerFailed": "更新觸發器失敗:{{errorMessage}}"
}
}
}
diff --git a/web/public/locales/zh-Hant/views/system.json b/web/public/locales/zh-Hant/views/system.json
index b3d761047..e956b9a42 100644
--- a/web/public/locales/zh-Hant/views/system.json
+++ b/web/public/locales/zh-Hant/views/system.json
@@ -2,8 +2,8 @@
"documentTitle": {
"cameras": "鏡頭統計 - Frigate",
"storage": "儲存裝置統計 - Frigate",
- "general": "統計總覽 - Frigate",
- "enrichments": "進階統計 - Frigate",
+ "general": "一般統計 - Frigate",
+ "enrichments": "進階功能統計 - Frigate",
"logs": {
"frigate": "Frigate 日誌 - Frigate",
"go2rtc": "Go2RTC 日誌 - Frigate",
@@ -42,7 +42,8 @@
"inferenceSpeed": "偵測器推理速度",
"temperature": "偵測器溫度",
"cpuUsage": "偵測器 CPU 使用率",
- "memoryUsage": "偵測器記憶體使用量"
+ "memoryUsage": "偵測器記憶體使用量",
+ "cpuUsageInformation": "用於準備輸入和輸出數據至/從偵測模型的CPU。此值不衡量推論使用量,即使使用GPU或加速器。"
},
"hardwareInfo": {
"title": "硬體資訊",
@@ -75,12 +76,24 @@
}
},
"npuUsage": "NPU 使用率",
- "npuMemory": "NPU 記憶體"
+ "npuMemory": "NPU 記憶體",
+ "intelGpuWarning": {
+ "title": "Intel GPU 狀態警告",
+ "message": "GPU 狀態資訊不可用",
+ "description": "這是一個在Intel GPU 狀態回報工具 (intel_gpu_top) 中已知的 Bug,該工具會故障並重複的回報 GPU占用率為 0%,甚至在硬體加速與物件偵測在 (i)GPU上正確運作時也是如此。這不是 Frigate 的 Bug。您可以透過重新啟動主機來暫時修復此問題以確認 GPU 運作正常。這不會影響效能。"
+ }
},
"otherProcesses": {
"title": "其他行程",
"processCpuUsage": "行程 CPU 使用率",
- "processMemoryUsage": "行程記憶體使用量"
+ "processMemoryUsage": "行程記憶體使用量",
+ "series": {
+ "recording": "记录",
+ "review_segment": "评论部分",
+ "embeddings": "嵌入",
+ "audio_detector": "音訊偵測器",
+ "go2rtc": "go2rtc"
+ }
}
},
"storage": {
@@ -102,6 +115,10 @@
"title": "未使用",
"tips": "在磁碟中有除了 Frigate 錄影內容以外的檔案時,此數值可能無法正確反應可用的空間。Frigate 不會追蹤錄影資料以外的檔案的儲存空間用量。"
}
+ },
+ "shm": {
+ "title": "SHM(共享記憶體)配置",
+ "warning": "目前的 SHM 大小為 {{total}}MB,過小。請將其增加至至少 {{min_shm}}MB。"
}
},
"cameras": {
@@ -158,7 +175,8 @@
"reindexingEmbeddings": "正在重新替嵌入資料建立索引(已完成 {{processed}}%)",
"cameraIsOffline": "{{camera}} 已離線",
"detectIsSlow": "{{detect}} 偵測速度較慢({{speed}} 毫秒)",
- "detectIsVerySlow": "{{detect}} 偵測速度緩慢({{speed}} 毫秒)"
+ "detectIsVerySlow": "{{detect}} 偵測速度緩慢({{speed}} 毫秒)",
+ "shmTooLow": "/dev/shm 配置({{total}} MB)應增加至至少{{min}} MB。"
},
"enrichments": {
"title": "進階功能",
@@ -174,7 +192,17 @@
"plate_recognition_speed": "車牌辨識速度",
"text_embedding_speed": "文字提取速度",
"yolov9_plate_detection_speed": "YOLOv9 車牌偵測速度",
- "yolov9_plate_detection": "YOLOv9 車牌辨識"
- }
+ "yolov9_plate_detection": "YOLOv9 車牌辨識",
+ "review_description": "審查說明",
+ "review_description_speed": "審查描述速度",
+ "review_description_events_per_second": "審查說明",
+ "object_description": "物件說明",
+ "object_description_speed": "物件說明速度",
+ "object_description_events_per_second": "物件說明",
+ "classification": "{{name}} 分類",
+ "classification_speed": "{{name}}分類速度",
+ "classification_events_per_second": "{{name}} 分類每秒事件數"
+ },
+ "averageInf": "平均推論時間"
}
}
diff --git a/web/public/notifications-worker.js b/web/public/notifications-worker.js
index ab8a6ae44..ba4e033ea 100644
--- a/web/public/notifications-worker.js
+++ b/web/public/notifications-worker.js
@@ -44,11 +44,16 @@ self.addEventListener("notificationclick", (event) => {
switch (event.action ?? "default") {
case "markReviewed":
if (event.notification.data) {
- fetch("/api/reviews/viewed", {
- method: "POST",
- headers: { "Content-Type": "application/json", "X-CSRF-TOKEN": 1 },
- body: JSON.stringify({ ids: [event.notification.data.id] }),
- });
+ event.waitUntil(
+ fetch("/api/reviews/viewed", {
+ method: "POST",
+ headers: {
+ "Content-Type": "application/json",
+ "X-CSRF-TOKEN": 1,
+ },
+ body: JSON.stringify({ ids: [event.notification.data.id] }),
+ }), // eslint-disable-line comma-dangle
+ );
}
break;
default:
@@ -58,7 +63,7 @@ self.addEventListener("notificationclick", (event) => {
// eslint-disable-next-line no-undef
if (clients.openWindow) {
// eslint-disable-next-line no-undef
- return clients.openWindow(url);
+ event.waitUntil(clients.openWindow(url));
}
}
}
diff --git a/web/src/App.tsx b/web/src/App.tsx
index a0062549f..d7a9ec3e9 100644
--- a/web/src/App.tsx
+++ b/web/src/App.tsx
@@ -12,6 +12,10 @@ import { cn } from "./lib/utils";
import { isPWA } from "./utils/isPWA";
import ProtectedRoute from "@/components/auth/ProtectedRoute";
import { AuthProvider } from "@/context/auth-context";
+import useSWR from "swr";
+import { FrigateConfig } from "./types/frigateConfig";
+import ActivityIndicator from "@/components/indicators/activity-indicator";
+import { isRedirectingToLogin } from "@/api/auth-redirect";
const Live = lazy(() => import("@/pages/Live"));
const Events = lazy(() => import("@/pages/Events"));
@@ -22,56 +26,21 @@ const System = lazy(() => import("@/pages/System"));
const Settings = lazy(() => import("@/pages/Settings"));
const UIPlayground = lazy(() => import("@/pages/UIPlayground"));
const FaceLibrary = lazy(() => import("@/pages/FaceLibrary"));
+const Classification = lazy(() => import("@/pages/ClassificationModel"));
const Logs = lazy(() => import("@/pages/Logs"));
const AccessDenied = lazy(() => import("@/pages/AccessDenied"));
function App() {
+ const { data: config } = useSWR("config", {
+ revalidateOnFocus: false,
+ });
+
return (
-
- {isDesktop && }
- {isDesktop && }
- {isMobile && }
-
-
-
-
- }
- >
- } />
- } />
- } />
- } />
- } />
-
- }
- >
- } />
- } />
- } />
- } />
- } />
-
- } />
- } />
-
-
-
-
+ {config?.safe_mode ? : }
@@ -79,4 +48,88 @@ function App() {
);
}
+function DefaultAppView() {
+ const { data: config } = useSWR("config", {
+ revalidateOnFocus: false,
+ });
+
+ // Compute required roles for main routes, ensuring we have config first
+ // to prevent race condition where custom roles are temporarily unavailable
+ const mainRouteRoles = config?.auth?.roles
+ ? Object.keys(config.auth.roles)
+ : undefined;
+
+ // Show loading indicator during redirect to prevent React from attempting to render
+ // lazy components, which would cause error #426 (suspension during synchronous navigation)
+ if (isRedirectingToLogin()) {
+ return (
+
+
+
+ );
+ }
+
+ return (
+
+ {isDesktop && }
+ {isDesktop && }
+ {isMobile && }
+
+
+
+
+ ) : (
+
+ )
+ }
+ >
+ } />
+ } />
+ } />
+ } />
+ } />
+
+ }>
+ } />
+ } />
+ } />
+ } />
+ } />
+ } />
+
+ } />
+ } />
+
+
+
+
+ );
+}
+
+function SafeAppView() {
+ return (
+
+
+
+
+
+
+
+ );
+}
+
export default App;
diff --git a/web/src/api/auth-redirect.ts b/web/src/api/auth-redirect.ts
new file mode 100644
index 000000000..f19e2b8a5
--- /dev/null
+++ b/web/src/api/auth-redirect.ts
@@ -0,0 +1,12 @@
+// Module-level flag to prevent multiple simultaneous redirects
+// (eg, when multiple SWR queries fail with 401 at once, or when
+// both ApiProvider and ProtectedRoute try to redirect)
+let _isRedirectingToLogin = false;
+
+export function isRedirectingToLogin(): boolean {
+ return _isRedirectingToLogin;
+}
+
+export function setRedirectingToLogin(value: boolean): void {
+ _isRedirectingToLogin = value;
+}
diff --git a/web/src/api/index.tsx b/web/src/api/index.tsx
index a9044a6d7..e5c5617ab 100644
--- a/web/src/api/index.tsx
+++ b/web/src/api/index.tsx
@@ -3,6 +3,7 @@ import { SWRConfig } from "swr";
import { WsProvider } from "./ws";
import axios from "axios";
import { ReactNode } from "react";
+import { isRedirectingToLogin, setRedirectingToLogin } from "./auth-redirect";
axios.defaults.baseURL = `${baseUrl}api/`;
@@ -31,7 +32,8 @@ export function ApiProvider({ children, options }: ApiProviderType) {
) {
// redirect to the login page if not already there
const loginPage = error.response.headers.get("location") ?? "login";
- if (window.location.href !== loginPage) {
+ if (window.location.href !== loginPage && !isRedirectingToLogin()) {
+ setRedirectingToLogin(true);
window.location.href = loginPage;
}
}
diff --git a/web/src/api/ws.tsx b/web/src/api/ws.tsx
index 3e9c8c14f..44d45ea2f 100644
--- a/web/src/api/ws.tsx
+++ b/web/src/api/ws.tsx
@@ -8,6 +8,9 @@ import {
FrigateReview,
ModelState,
ToggleableSetting,
+ TrackedObjectUpdateReturnType,
+ TriggerStatus,
+ FrigateAudioDetections,
} from "@/types/ws";
import { FrigateStats } from "@/types/stats";
import { createContainer } from "react-tracked";
@@ -30,14 +33,9 @@ function useValue(): useValueReturn {
// main state
- const [hasCameraState, setHasCameraState] = useState(false);
const [wsState, setWsState] = useState({});
useEffect(() => {
- if (hasCameraState) {
- return;
- }
-
const activityValue: string = wsState["camera_activity"] as string;
if (!activityValue) {
@@ -60,17 +58,23 @@ function useValue(): useValueReturn {
enabled,
snapshots,
audio,
+ audio_transcription,
notifications,
notifications_suspended,
autotracking,
alerts,
detections,
+ object_descriptions,
+ review_descriptions,
} = state["config"];
cameraStates[`${name}/recordings/state`] = record ? "ON" : "OFF";
cameraStates[`${name}/enabled/state`] = enabled ? "ON" : "OFF";
cameraStates[`${name}/detect/state`] = detect ? "ON" : "OFF";
cameraStates[`${name}/snapshots/state`] = snapshots ? "ON" : "OFF";
cameraStates[`${name}/audio/state`] = audio ? "ON" : "OFF";
+ cameraStates[`${name}/audio_transcription/state`] = audio_transcription
+ ? "ON"
+ : "OFF";
cameraStates[`${name}/notifications/state`] = notifications
? "ON"
: "OFF";
@@ -83,6 +87,12 @@ function useValue(): useValueReturn {
cameraStates[`${name}/review_detections/state`] = detections
? "ON"
: "OFF";
+ cameraStates[`${name}/object_descriptions/state`] = object_descriptions
+ ? "ON"
+ : "OFF";
+ cameraStates[`${name}/review_descriptions/state`] = review_descriptions
+ ? "ON"
+ : "OFF";
});
setWsState((prevState) => ({
@@ -90,12 +100,9 @@ function useValue(): useValueReturn {
...cameraStates,
}));
- if (Object.keys(cameraStates).length > 0) {
- setHasCameraState(true);
- }
// we only want this to run initially when the config is loaded
// eslint-disable-next-line react-hooks/exhaustive-deps
- }, [wsState]);
+ }, [wsState["camera_activity"]]);
// ws handler
const { sendJsonMessage, readyState } = useWebSocket(wsUrl, {
@@ -116,9 +123,7 @@ function useValue(): useValueReturn {
retain: false,
});
},
- onClose: () => {
- setHasCameraState(false);
- },
+ onClose: () => {},
shouldReconnect: () => true,
retryOnError: true,
});
@@ -220,6 +225,20 @@ export function useAudioState(camera: string): {
return { payload: payload as ToggleableSetting, send };
}
+export function useAudioTranscriptionState(camera: string): {
+ payload: ToggleableSetting;
+ send: (payload: ToggleableSetting, retain?: boolean) => void;
+} {
+ const {
+ value: { payload },
+ send,
+ } = useWs(
+ `${camera}/audio_transcription/state`,
+ `${camera}/audio_transcription/set`,
+ );
+ return { payload: payload as ToggleableSetting, send };
+}
+
export function useAutotrackingState(camera: string): {
payload: ToggleableSetting;
send: (payload: ToggleableSetting, retain?: boolean) => void;
@@ -256,6 +275,34 @@ export function useDetectionsState(camera: string): {
return { payload: payload as ToggleableSetting, send };
}
+export function useObjectDescriptionState(camera: string): {
+ payload: ToggleableSetting;
+ send: (payload: ToggleableSetting, retain?: boolean) => void;
+} {
+ const {
+ value: { payload },
+ send,
+ } = useWs(
+ `${camera}/object_descriptions/state`,
+ `${camera}/object_descriptions/set`,
+ );
+ return { payload: payload as ToggleableSetting, send };
+}
+
+export function useReviewDescriptionState(camera: string): {
+ payload: ToggleableSetting;
+ send: (payload: ToggleableSetting, retain?: boolean) => void;
+} {
+ const {
+ value: { payload },
+ send,
+ } = useWs(
+ `${camera}/review_descriptions/state`,
+ `${camera}/review_descriptions/set`,
+ );
+ return { payload: payload as ToggleableSetting, send };
+}
+
export function usePtzCommand(camera: string): {
payload: string;
send: (payload: string, retain?: boolean) => void;
@@ -285,6 +332,13 @@ export function useFrigateEvents(): { payload: FrigateEvent } {
return { payload: JSON.parse(payload as string) };
}
+export function useAudioDetections(): { payload: FrigateAudioDetections } {
+ const {
+ value: { payload },
+ } = useWs("audio_detections", "");
+ return { payload: JSON.parse(payload as string) };
+}
+
export function useFrigateReviews(): FrigateReview {
const {
value: { payload },
@@ -407,6 +461,74 @@ export function useEmbeddingsReindexProgress(
return { payload: data };
}
+export function useAudioTranscriptionProcessState(
+ revalidateOnFocus: boolean = true,
+): { payload: string } {
+ const {
+ value: { payload },
+ send: sendCommand,
+ } = useWs("audio_transcription_state", "audioTranscriptionState");
+
+ const data = useDeepMemo(
+ payload ? (JSON.parse(payload as string) as string) : "idle",
+ );
+
+ useEffect(() => {
+ let listener = undefined;
+ if (revalidateOnFocus) {
+ sendCommand("audioTranscriptionState");
+ listener = () => {
+ if (document.visibilityState == "visible") {
+ sendCommand("audioTranscriptionState");
+ }
+ };
+ addEventListener("visibilitychange", listener);
+ }
+ return () => {
+ if (listener) {
+ removeEventListener("visibilitychange", listener);
+ }
+ };
+ // eslint-disable-next-line react-hooks/exhaustive-deps
+ }, [revalidateOnFocus]);
+
+ return { payload: data || "idle" };
+}
+
+export function useBirdseyeLayout(revalidateOnFocus: boolean = true): {
+ payload: string;
+} {
+ const {
+ value: { payload },
+ send: sendCommand,
+ } = useWs("birdseye_layout", "birdseyeLayout");
+
+ const data = useDeepMemo(JSON.parse(payload as string));
+
+ useEffect(() => {
+ let listener = undefined;
+ if (revalidateOnFocus) {
+ sendCommand("birdseyeLayout");
+ listener = () => {
+ if (document.visibilityState == "visible") {
+ sendCommand("birdseyeLayout");
+ }
+ };
+ addEventListener("visibilitychange", listener);
+ }
+
+ return () => {
+ if (listener) {
+ removeEventListener("visibilitychange", listener);
+ }
+ };
+ // we know that these deps are correct
+ // eslint-disable-next-line react-hooks/exhaustive-deps
+ }, [revalidateOnFocus]);
+
+ return { payload: data };
+}
+
export function useMotionActivity(camera: string): { payload: string } {
const {
value: { payload },
@@ -421,6 +543,15 @@ export function useAudioActivity(camera: string): { payload: number } {
return { payload: payload as number };
}
+export function useAudioLiveTranscription(camera: string): {
+ payload: string;
+} {
+ const {
+ value: { payload },
+ } = useWs(`${camera}/audio/transcription`, "");
+ return { payload: payload as string };
+}
+
export function useMotionThreshold(camera: string): {
payload: string;
send: (payload: number, retain?: boolean) => void;
@@ -463,11 +594,16 @@ export function useImproveContrast(camera: string): {
return { payload: payload as ToggleableSetting, send };
}
-export function useTrackedObjectUpdate(): { payload: string } {
+export function useTrackedObjectUpdate(): {
+ payload: TrackedObjectUpdateReturnType;
+} {
const {
value: { payload },
} = useWs("tracked_object_update", "");
- return useDeepMemo(JSON.parse(payload as string));
+ const parsed = payload
+ ? JSON.parse(payload as string)
+ : { type: "", id: "", camera: "" };
+ return { payload: useDeepMemo(parsed) };
}
export function useNotifications(camera: string): {
@@ -505,3 +641,13 @@ export function useNotificationTest(): {
} = useWs("notification_test", "notification_test");
return { payload: payload as string, send };
}
+
+export function useTriggers(): { payload: TriggerStatus } {
+ const {
+ value: { payload },
+ } = useWs("triggers", "");
+ const parsed = payload
+ ? JSON.parse(payload as string)
+ : { name: "", camera: "", event_id: "", type: "", score: 0 };
+ return { payload: useDeepMemo(parsed) };
+}
diff --git a/web/src/components/Statusbar.tsx b/web/src/components/Statusbar.tsx
index 0ac6d10a4..ab22a1143 100644
--- a/web/src/components/Statusbar.tsx
+++ b/web/src/components/Statusbar.tsx
@@ -116,10 +116,10 @@ export default function Statusbar() {
}
return (
-
+
{" "}
([]);
+ const [maxDataPoints] = useState(50);
+
+ // config for time formatting
+ const { data: config } = useSWR("config", {
+ revalidateOnFocus: false,
+ });
+ const locale = useDateLocale();
+ const { t } = useTranslation(["common"]);
+
+ const {
+ value: { payload: audioRms },
+ } = useWs(`${cameraName}/audio/rms`, "");
+ const {
+ value: { payload: audioDBFS },
+ } = useWs(`${cameraName}/audio/dBFS`, "");
+
+ useEffect(() => {
+ if (typeof audioRms === "number") {
+ const now = Date.now();
+ setAudioData((prev) => {
+ const next = [
+ ...prev,
+ {
+ timestamp: now,
+ rms: audioRms,
+ dBFS: typeof audioDBFS === "number" ? audioDBFS : 0,
+ },
+ ];
+ return next.slice(-maxDataPoints);
+ });
+ }
+ }, [audioRms, audioDBFS, maxDataPoints]);
+
+ const series = useMemo(
+ () => [
+ {
+ name: "RMS",
+ data: audioData.map((p) => ({ x: p.timestamp, y: p.rms })),
+ },
+ {
+ name: "dBFS",
+ data: audioData.map((p) => ({ x: p.timestamp, y: p.dBFS })),
+ },
+ ],
+ [audioData],
+ );
+
+ const lastValues = useMemo(() => {
+ if (!audioData.length) return undefined;
+ const last = audioData[audioData.length - 1];
+ return [last.rms, last.dBFS];
+ }, [audioData]);
+
+ const timeFormat = config?.ui.time_format === "24hour" ? "24hour" : "12hour";
+ const formatString = useMemo(
+ () =>
+ t(`time.formattedTimestampHourMinuteSecond.${timeFormat}`, {
+ ns: "common",
+ }),
+ [t, timeFormat],
+ );
+
+ const formatTime = useCallback(
+ (val: unknown) => {
+ const seconds = Math.round(Number(val) / 1000);
+ return formatUnixTimestampToDateTime(seconds, {
+ timezone: config?.ui.timezone,
+ date_format: formatString,
+ locale,
+ });
+ },
+ [config?.ui.timezone, formatString, locale],
+ );
+
+ const { theme, systemTheme } = useTheme();
+
+ const options = useMemo(() => {
+ return {
+ chart: {
+ id: `${cameraName}-audio`,
+ selection: { enabled: false },
+ toolbar: { show: false },
+ zoom: { enabled: false },
+ animations: { enabled: false },
+ },
+ colors: GRAPH_COLORS,
+ grid: {
+ show: true,
+ borderColor: "#374151",
+ strokeDashArray: 3,
+ xaxis: { lines: { show: true } },
+ yaxis: { lines: { show: true } },
+ },
+ legend: { show: false },
+ dataLabels: { enabled: false },
+ stroke: { width: 1 },
+ markers: { size: 0 },
+ tooltip: {
+ theme: systemTheme || theme,
+ x: { formatter: (val: number) => formatTime(val) },
+ y: { formatter: (v: number) => v.toFixed(1) },
+ },
+ xaxis: {
+ type: "datetime",
+ labels: {
+ rotate: 0,
+ formatter: formatTime,
+ style: { colors: "#6B6B6B", fontSize: "10px" },
+ },
+ axisBorder: { show: false },
+ axisTicks: { show: false },
+ },
+ yaxis: {
+ show: true,
+ labels: {
+ formatter: (val: number) => Math.round(val).toString(),
+ style: { colors: "#6B6B6B", fontSize: "10px" },
+ },
+ },
+ } as ApexCharts.ApexOptions;
+ }, [cameraName, theme, systemTheme, formatTime]);
+
+ return (
+
+ {lastValues && (
+
+ {["RMS", "dBFS"].map((label, idx) => (
+
+
+ {label}
+
+ {lastValues[idx].toFixed(1)}
+
+
+ ))}
+
+ )}
+
+
+ );
+}
diff --git a/web/src/components/auth/AuthForm.tsx b/web/src/components/auth/AuthForm.tsx
index 12e8f777e..8798b5d00 100644
--- a/web/src/components/auth/AuthForm.tsx
+++ b/web/src/components/auth/AuthForm.tsx
@@ -22,14 +22,24 @@ import { zodResolver } from "@hookform/resolvers/zod";
import { z } from "zod";
import { AuthContext } from "@/context/auth-context";
import { useTranslation } from "react-i18next";
+import useSWR from "swr";
+import { LuExternalLink } from "react-icons/lu";
+import { useDocDomain } from "@/hooks/use-doc-domain";
+import { Card, CardContent } from "@/components/ui/card";
interface UserAuthFormProps extends React.HTMLAttributes {}
export function UserAuthForm({ className, ...props }: UserAuthFormProps) {
- const { t } = useTranslation(["components/auth"]);
+ const { t } = useTranslation(["components/auth", "common"]);
+ const { getLocaleDocUrl } = useDocDomain();
const [isLoading, setIsLoading] = React.useState(false);
const { login } = React.useContext(AuthContext);
+ // need to use local fetcher because useSWR default fetcher is not set up in this context
+ const fetcher = (path: string) => axios.get(path).then((res) => res.data);
+ const { data } = useSWR("/auth/first_time_login", fetcher);
+ const showFirstTimeLink = data?.admin_first_time_login === true;
+
const formSchema = z.object({
user: z.string().min(1, t("form.errors.usernameRequired")),
password: z.string().min(1, t("form.errors.passwordRequired")),
@@ -136,6 +146,24 @@ export function UserAuthForm({ className, ...props }: UserAuthFormProps) {
+ {showFirstTimeLink && (
+
+
+
+ {t("form.firstTimeLogin")}
+
+
+ {t("readTheDocumentation", { ns: "common" })}
+
+
+
+
+ )}
);
diff --git a/web/src/components/auth/ProtectedRoute.tsx b/web/src/components/auth/ProtectedRoute.tsx
index c35fdaebc..cedf5a15a 100644
--- a/web/src/components/auth/ProtectedRoute.tsx
+++ b/web/src/components/auth/ProtectedRoute.tsx
@@ -1,15 +1,41 @@
-import { useContext } from "react";
+import { useContext, useEffect } from "react";
import { Navigate, Outlet } from "react-router-dom";
import { AuthContext } from "@/context/auth-context";
import ActivityIndicator from "../indicators/activity-indicator";
+import {
+ isRedirectingToLogin,
+ setRedirectingToLogin,
+} from "@/api/auth-redirect";
export default function ProtectedRoute({
requiredRoles,
}: {
- requiredRoles: ("admin" | "viewer")[];
+ requiredRoles: string[];
}) {
const { auth } = useContext(AuthContext);
+ // Redirect to login page when not authenticated
+ // don't use because we need a full page load to reset state
+ useEffect(() => {
+ if (
+ !auth.isLoading &&
+ auth.isAuthenticated &&
+ !auth.user &&
+ !isRedirectingToLogin()
+ ) {
+ setRedirectingToLogin(true);
+ window.location.href = "/login";
+ }
+ }, [auth.isLoading, auth.isAuthenticated, auth.user]);
+
+ // Show loading indicator during redirect to prevent React from attempting to render
+ // lazy components, which would cause error #426 (suspension during synchronous navigation)
+ if (isRedirectingToLogin()) {
+ return (
+
+ );
+ }
+
if (auth.isLoading) {
return (
@@ -23,7 +49,9 @@ export default function ProtectedRoute({
// Authenticated mode (8971): require login
if (!auth.user) {
- return ;
+ return (
+
+ );
}
// If role is null (shouldn’t happen if isAuthenticated, but type safety), fallback
diff --git a/web/src/components/button/BlurredIconButton.tsx b/web/src/components/button/BlurredIconButton.tsx
new file mode 100644
index 000000000..8fe17f869
--- /dev/null
+++ b/web/src/components/button/BlurredIconButton.tsx
@@ -0,0 +1,28 @@
+import React, { forwardRef } from "react";
+import { cn } from "@/lib/utils";
+
+type BlurredIconButtonProps = React.HTMLAttributes;
+
+const BlurredIconButton = forwardRef(
+ ({ className = "", children, ...rest }, ref) => {
+ return (
+
+
+
+ {children}
+
+
+ );
+ },
+);
+
+BlurredIconButton.displayName = "BlurredIconButton";
+
+export default BlurredIconButton;
diff --git a/web/src/components/camera/DebugCameraImage.tsx b/web/src/components/camera/DebugCameraImage.tsx
index 3d840d0d3..924eb86a5 100644
--- a/web/src/components/camera/DebugCameraImage.tsx
+++ b/web/src/components/camera/DebugCameraImage.tsx
@@ -5,7 +5,7 @@ import { Button } from "../ui/button";
import { LuSettings } from "react-icons/lu";
import { useCallback, useMemo, useState } from "react";
import { Card, CardContent, CardHeader, CardTitle } from "../ui/card";
-import { usePersistence } from "@/hooks/use-persistence";
+import { useUserPersistence } from "@/hooks/use-user-persistence";
import AutoUpdatingCameraImage from "./AutoUpdatingCameraImage";
import { useTranslation } from "react-i18next";
@@ -24,7 +24,7 @@ export default function DebugCameraImage({
}: DebugCameraImageProps) {
const { t } = useTranslation(["components/camera"]);
const [showSettings, setShowSettings] = useState(false);
- const [options, setOptions] = usePersistence(
+ const [options, setOptions] = useUserPersistence(
`${cameraConfig?.name}-feed`,
emptyObject,
);
@@ -158,6 +158,16 @@ function DebugSettings({ handleSetOption, options }: DebugSettingsProps) {
/>
+
+ {
+ handleSetOption("paths", isChecked);
+ }}
+ />
+
+
);
}
diff --git a/web/src/components/camera/FriendlyNameLabel.tsx b/web/src/components/camera/FriendlyNameLabel.tsx
new file mode 100644
index 000000000..ca0978852
--- /dev/null
+++ b/web/src/components/camera/FriendlyNameLabel.tsx
@@ -0,0 +1,44 @@
+import * as React from "react";
+import * as LabelPrimitive from "@radix-ui/react-label";
+import { useCameraFriendlyName } from "@/hooks/use-camera-friendly-name";
+import { CameraConfig } from "@/types/frigateConfig";
+import { useZoneFriendlyName } from "@/hooks/use-zone-friendly-name";
+
+interface CameraNameLabelProps
+ extends React.ComponentPropsWithoutRef {
+ camera?: string | CameraConfig;
+}
+
+interface ZoneNameLabelProps
+ extends React.ComponentPropsWithoutRef {
+ zone: string;
+ camera?: string;
+}
+
+const CameraNameLabel = React.forwardRef<
+ React.ElementRef,
+ CameraNameLabelProps
+>(({ className, camera, ...props }, ref) => {
+ const displayName = useCameraFriendlyName(camera);
+ return (
+
+ {displayName}
+
+ );
+});
+CameraNameLabel.displayName = LabelPrimitive.Root.displayName;
+
+const ZoneNameLabel = React.forwardRef<
+ React.ElementRef,
+ ZoneNameLabelProps
+>(({ className, zone, camera, ...props }, ref) => {
+ const displayName = useZoneFriendlyName(zone, camera);
+ return (
+
+ {displayName}
+
+ );
+});
+ZoneNameLabel.displayName = LabelPrimitive.Root.displayName;
+
+export { CameraNameLabel, ZoneNameLabel };
diff --git a/web/src/components/card/AnimatedEventCard.tsx b/web/src/components/card/AnimatedEventCard.tsx
index d46509eb6..63cda9d0b 100644
--- a/web/src/components/card/AnimatedEventCard.tsx
+++ b/web/src/components/card/AnimatedEventCard.tsx
@@ -12,13 +12,15 @@ import { useCameraPreviews } from "@/hooks/use-camera-previews";
import { baseUrl } from "@/api/baseUrl";
import { VideoPreview } from "../preview/ScrubbablePreview";
import { useApiHost } from "@/api";
-import { isDesktop, isSafari } from "react-device-detect";
-import { usePersistence } from "@/hooks/use-persistence";
+import { isSafari } from "react-device-detect";
+import { useUserPersistence } from "@/hooks/use-user-persistence";
import { Skeleton } from "../ui/skeleton";
import { Button } from "../ui/button";
import { FaCircleCheck } from "react-icons/fa6";
import { cn } from "@/lib/utils";
import { useTranslation } from "react-i18next";
+import { getTranslatedLabel } from "@/utils/i18n";
+import { formatList } from "@/utils/stringUtil";
type AnimatedEventCardProps = {
event: ReviewSegment;
@@ -50,6 +52,36 @@ export function AnimatedEventCard({
fetchPreviews: !currentHour,
});
+ const getEventType = useCallback(
+ (text: string) => {
+ if (event.data.sub_labels?.includes(text)) return "manual";
+ if (event.data.audio.includes(text)) return "audio";
+ return "object";
+ },
+ [event],
+ );
+
+ const tooltipText = useMemo(() => {
+ if (event?.data?.metadata?.title) {
+ return event.data.metadata.title;
+ }
+
+ return (
+ `${formatList(
+ [
+ ...new Set([
+ ...(event.data.objects || []),
+ ...(event.data.sub_labels || []),
+ ...(event.data.audio || []),
+ ]),
+ ]
+ .filter((item) => item !== undefined && !item.includes("-verified"))
+ .map((text) => getTranslatedLabel(text, getEventType(text)))
+ .sort(),
+ )} ` + t("detected")
+ );
+ }, [event, getEventType, t]);
+
// visibility
const [windowVisible, setWindowVisible] = useState(true);
@@ -66,7 +98,6 @@ export function AnimatedEventCard({
}, [visibilityListener]);
const [isLoaded, setIsLoaded] = useState(false);
- const [isHovered, setIsHovered] = useState(false);
// interaction
@@ -91,7 +122,10 @@ export function AnimatedEventCard({
// image behavior
- const [alertVideos] = usePersistence("alertVideos", true);
+ const [alertVideos, _, alertVideosLoaded] = useUserPersistence(
+ "alertVideos",
+ true,
+ );
const aspectRatio = useMemo(() => {
if (
@@ -110,32 +144,28 @@ export function AnimatedEventCard({
setIsHovered(true) : undefined}
- onMouseLeave={isDesktop ? () => setIsHovered(false) : undefined}
>
- {isHovered && (
-
-
-
-
- {t("markAsReviewed")}
-
- )}
- {previews != undefined && (
+
+
+
+
+ {t("markAsReviewed")}
+
+ {previews != undefined && alertVideosLoaded && (
-
- {`${[
- ...new Set([
- ...(event.data.objects || []),
- ...(event.data.sub_labels || []),
- ...(event.data.audio || []),
- ]),
- ]
- .filter((item) => item !== undefined && !item.includes("-verified"))
- .map((text) => text.charAt(0).toUpperCase() + text.substring(1))
- .sort()
- .join(", ")
- .replaceAll("-verified", "")} ` + t("detected")}
-
+ {tooltipText}
);
}
diff --git a/web/src/components/card/ClassificationCard.tsx b/web/src/components/card/ClassificationCard.tsx
new file mode 100644
index 000000000..6581d109a
--- /dev/null
+++ b/web/src/components/card/ClassificationCard.tsx
@@ -0,0 +1,438 @@
+import { baseUrl } from "@/api/baseUrl";
+import useContextMenu from "@/hooks/use-contextmenu";
+import { cn } from "@/lib/utils";
+import {
+ ClassificationItemData,
+ ClassificationThreshold,
+ ClassifiedEvent,
+} from "@/types/classification";
+import { forwardRef, useMemo, useRef, useState } from "react";
+import { isDesktop, isIOS, isMobile, isMobileOnly } from "react-device-detect";
+import { useTranslation } from "react-i18next";
+import TimeAgo from "../dynamic/TimeAgo";
+import { Tooltip, TooltipContent, TooltipTrigger } from "../ui/tooltip";
+import { Popover, PopoverContent, PopoverTrigger } from "../ui/popover";
+import { LuSearch, LuInfo } from "react-icons/lu";
+import { TooltipPortal } from "@radix-ui/react-tooltip";
+import { useNavigate } from "react-router-dom";
+import { HiSquare2Stack } from "react-icons/hi2";
+import { ImageShadowOverlay } from "../overlay/ImageShadowOverlay";
+import {
+ Dialog,
+ DialogContent,
+ DialogDescription,
+ DialogHeader,
+ DialogTitle,
+ DialogTrigger,
+} from "../ui/dialog";
+import {
+ MobilePage,
+ MobilePageContent,
+ MobilePageDescription,
+ MobilePageHeader,
+ MobilePageTitle,
+ MobilePageTrigger,
+} from "../mobile/MobilePage";
+
+type ClassificationCardProps = {
+ className?: string;
+ imgClassName?: string;
+ data: ClassificationItemData;
+ threshold?: ClassificationThreshold;
+ selected: boolean;
+ clickable: boolean;
+ i18nLibrary: string;
+ showArea?: boolean;
+ count?: number;
+ onClick: (data: ClassificationItemData, meta: boolean) => void;
+ children?: React.ReactNode;
+};
+export const ClassificationCard = forwardRef<
+ HTMLDivElement,
+ ClassificationCardProps
+>(function ClassificationCard(
+ {
+ className,
+ imgClassName,
+ data,
+ threshold,
+ selected,
+ clickable,
+ i18nLibrary,
+ showArea = true,
+ count,
+ onClick,
+ children,
+ },
+ ref,
+) {
+ const { t } = useTranslation([i18nLibrary]);
+ const [imageLoaded, setImageLoaded] = useState(false);
+
+ const scoreStatus = useMemo(() => {
+ if (!data.score || !threshold) {
+ return "unknown";
+ }
+
+ if (data.score >= threshold.recognition) {
+ return "match";
+ } else if (data.score >= threshold.unknown) {
+ return "potential";
+ } else {
+ return "unknown";
+ }
+ }, [data, threshold]);
+
+ // interaction
+
+ const imgRef = useRef(null);
+
+ useContextMenu(imgRef, () => {
+ onClick(data, true);
+ });
+
+ const imageArea = useMemo(() => {
+ if (!showArea || imgRef.current == null || !imageLoaded) {
+ return undefined;
+ }
+
+ return imgRef.current.naturalWidth * imgRef.current.naturalHeight;
+ }, [showArea, imageLoaded]);
+
+ return (
+ {
+ const isMeta = e.metaKey || e.ctrlKey;
+ if (isMeta) {
+ e.stopPropagation();
+ }
+ onClick(data, isMeta);
+ }}
+ onContextMenu={(e) => {
+ e.preventDefault();
+ e.stopPropagation();
+ onClick(data, true);
+ }}
+ >
+
setImageLoaded(true)}
+ src={`${baseUrl}${data.filepath}`}
+ />
+
+ {count && (
+
+ {count}{" "}
+
+
+ )}
+ {!count && imageArea != undefined && (
+
+ {t("information.pixels", { ns: "common", area: imageArea })}
+
+ )}
+
+
+
+
+ {data.name.toLowerCase() == "unknown"
+ ? t("details.unknown")
+ : data.name.toLowerCase() == "none"
+ ? t("details.none")
+ : data.name}
+
+ {data.score != undefined && (
+
+ {Math.round(data.score * 100)}%
+
+ )}
+
+
+ {children}
+
+
+
+ );
+});
+
+type GroupedClassificationCardProps = {
+ group: ClassificationItemData[];
+ classifiedEvent?: ClassifiedEvent;
+ threshold?: ClassificationThreshold;
+ selectedItems: string[];
+ i18nLibrary: string;
+ objectType: string;
+ noClassificationLabel?: string;
+ onClick: (data: ClassificationItemData | undefined) => void;
+ children?: (data: ClassificationItemData) => React.ReactNode;
+};
+export function GroupedClassificationCard({
+ group,
+ classifiedEvent,
+ threshold,
+ selectedItems,
+ i18nLibrary,
+ noClassificationLabel = "details.none",
+ onClick,
+ children,
+}: GroupedClassificationCardProps) {
+ const navigate = useNavigate();
+ const { t } = useTranslation(["views/explore", i18nLibrary]);
+ const [detailOpen, setDetailOpen] = useState(false);
+
+ // data
+
+ const bestItem = useMemo(() => {
+ let best: undefined | ClassificationItemData = undefined;
+
+ group.forEach((item) => {
+ if (item?.name != undefined && item.name != "none") {
+ if (
+ best?.score == undefined ||
+ (item.score && best.score < item.score)
+ ) {
+ best = item;
+ }
+ }
+ });
+
+ if (!best) {
+ best = group.at(-1)!;
+ }
+
+ const bestTyped: ClassificationItemData = best;
+ return {
+ ...bestTyped,
+ name:
+ classifiedEvent?.label && classifiedEvent.label !== "none"
+ ? classifiedEvent.label
+ : classifiedEvent
+ ? t(noClassificationLabel)
+ : bestTyped.name,
+ score: classifiedEvent?.score,
+ };
+ }, [group, classifiedEvent, noClassificationLabel, t]);
+
+ const bestScoreStatus = useMemo(() => {
+ if (!bestItem?.score || !threshold) {
+ return "unknown";
+ }
+
+ if (bestItem.score >= threshold.recognition) {
+ return "match";
+ } else if (bestItem.score >= threshold.unknown) {
+ return "potential";
+ } else {
+ return "unknown";
+ }
+ }, [bestItem, threshold]);
+
+ const time = useMemo(() => {
+ const item = group[0];
+
+ if (!item?.timestamp) {
+ return undefined;
+ }
+
+ return item.timestamp * 1000;
+ }, [group]);
+
+ if (!bestItem) {
+ return null;
+ }
+
+ const Overlay = isDesktop ? Dialog : MobilePage;
+ const Trigger = isDesktop ? DialogTrigger : MobilePageTrigger;
+ const Content = isDesktop ? DialogContent : MobilePageContent;
+ const Header = isDesktop ? DialogHeader : MobilePageHeader;
+ const ContentTitle = isDesktop ? DialogTitle : MobilePageTitle;
+ const ContentDescription = isDesktop
+ ? DialogDescription
+ : MobilePageDescription;
+
+ return (
+ <>
+ {
+ if (meta || selectedItems.length > 0) {
+ onClick(undefined);
+ } else {
+ setDetailOpen(true);
+ }
+ }}
+ />
+ {
+ if (!open) {
+ setDetailOpen(false);
+ }
+ }}
+ >
+
+ e.preventDefault()}
+ >
+ <>
+
+
+
+ {classifiedEvent?.label && classifiedEvent.label !== "none"
+ ? classifiedEvent.label
+ : t(noClassificationLabel, { ns: i18nLibrary })}
+ {classifiedEvent?.label &&
+ classifiedEvent.label !== "none" &&
+ classifiedEvent.score !== undefined && (
+
+ {`${Math.round((classifiedEvent.score || 0) * 100)}%`}
+
+
+
+
+
+ {t("details.scoreInfo", { ns: i18nLibrary })}
+
+
+
+ )}
+
+
+ {time && (
+
+ )}
+
+
+ {classifiedEvent && (
+
+
+
+ {
+ navigate(`/explore?event_id=${classifiedEvent.id}`);
+ }}
+ >
+
+
+
+
+
+ {t("details.item.button.viewInExplore", {
+ ns: "views/explore",
+ })}
+
+
+
+
+ )}
+
+
+ {group.map((data: ClassificationItemData) => (
+
+ {}}
+ >
+ {children?.(data)}
+
+
+ ))}
+
+ >
+
+
+ >
+ );
+}
diff --git a/web/src/components/card/EmptyCard.tsx b/web/src/components/card/EmptyCard.tsx
new file mode 100644
index 000000000..b9943b31a
--- /dev/null
+++ b/web/src/components/card/EmptyCard.tsx
@@ -0,0 +1,49 @@
+import React from "react";
+import { Button } from "../ui/button";
+import Heading from "../ui/heading";
+import { Link } from "react-router-dom";
+import { cn } from "@/lib/utils";
+
+type EmptyCardProps = {
+ className?: string;
+ icon: React.ReactNode;
+ title: string;
+ titleHeading?: boolean;
+ description?: string;
+ buttonText?: string;
+ link?: string;
+};
+export function EmptyCard({
+ className,
+ icon,
+ title,
+ titleHeading = true,
+ description,
+ buttonText,
+ link,
+}: EmptyCardProps) {
+ let TitleComponent;
+
+ if (titleHeading) {
+ TitleComponent = {title} ;
+ } else {
+ TitleComponent = {title};
+ }
+
+ return (
+
+ {icon}
+ {TitleComponent}
+ {description && (
+
+ {description}
+
+ )}
+ {buttonText?.length && (
+
+ )}
+
+ );
+}
diff --git a/web/src/components/card/ExportCard.tsx b/web/src/components/card/ExportCard.tsx
index 9115e0509..021524532 100644
--- a/web/src/components/card/ExportCard.tsx
+++ b/web/src/components/card/ExportCard.tsx
@@ -4,7 +4,6 @@ import { Button } from "../ui/button";
import { useCallback, useState } from "react";
import { isDesktop, isMobile } from "react-device-detect";
import { FaDownload, FaPlay, FaShareAlt } from "react-icons/fa";
-import Chip from "../indicators/Chip";
import { Skeleton } from "../ui/skeleton";
import {
Dialog,
@@ -21,6 +20,10 @@ import { baseUrl } from "@/api/baseUrl";
import { cn } from "@/lib/utils";
import { shareOrCopy } from "@/utils/browserUtil";
import { useTranslation } from "react-i18next";
+import { ImageShadowOverlay } from "../overlay/ImageShadowOverlay";
+import BlurredIconButton from "../button/BlurredIconButton";
+import { Tooltip, TooltipContent, TooltipTrigger } from "../ui/tooltip";
+import { useIsAdmin } from "@/hooks/use-is-admin";
type ExportProps = {
className: string;
@@ -38,6 +41,7 @@ export default function ExportCard({
onDelete,
}: ExportProps) {
const { t } = useTranslation(["views/exports"]);
+ const isAdmin = useIsAdmin();
const [hovered, setHovered] = useState(false);
const [loading, setLoading] = useState(
exportedRecording.thumb_path.length > 0,
@@ -70,7 +74,10 @@ export default function ExportCard({
(editName.update?.length ?? 0) > 0
) {
submitRename();
+ return true;
}
+
+ return false;
},
);
@@ -142,7 +149,7 @@ export default function ExportCard({
<>
{exportedRecording.thumb_path.length > 0 ? (
setLoading(false)}
/>
@@ -152,56 +159,79 @@ export default function ExportCard({
>
)}
{hovered && (
-
+ <>
-
- {!exportedRecording.in_progress && (
-
- shareOrCopy(
- `${baseUrl}export?id=${exportedRecording.id}`,
- exportedRecording.name.replaceAll("_", " "),
- )
- }
- >
-
-
- )}
- {!exportedRecording.in_progress && (
-
-
-
-
-
- )}
- {!exportedRecording.in_progress && (
-
- setEditName({
- original: exportedRecording.name,
- update: undefined,
- })
- }
- >
-
-
- )}
-
- onDelete({
- file: exportedRecording.id,
- exportName: exportedRecording.name,
- })
- }
- >
-
-
+
+
+ {!exportedRecording.in_progress && (
+
+
+
+ shareOrCopy(
+ `${baseUrl}export?id=${exportedRecording.id}`,
+ exportedRecording.name.replaceAll("_", " "),
+ )
+ }
+ >
+
+
+
+ {t("tooltip.shareExport")}
+
+ )}
+ {!exportedRecording.in_progress && (
+
+
+
+
+
+
+
+
+ {t("tooltip.downloadVideo")}
+
+
+
+ )}
+ {isAdmin && !exportedRecording.in_progress && (
+
+
+
+ setEditName({
+ original: exportedRecording.name,
+ update: undefined,
+ })
+ }
+ >
+
+
+
+ {t("tooltip.editName")}
+
+ )}
+ {isAdmin && (
+
+
+
+ onDelete({
+ file: exportedRecording.id,
+ exportName: exportedRecording.name,
+ })
+ }
+ >
+
+
+
+ {t("tooltip.deleteExport")}
+
+ )}
+
{!exportedRecording.in_progress && (
@@ -216,15 +246,14 @@ export default function ExportCard({
)}
-
+ >
)}
{loading && (
)}
-
-
- {exportedRecording.name.replaceAll("_", " ")}
-
+
+
+ {exportedRecording.name.replaceAll("_", " ")}
>
diff --git a/web/src/components/card/ReviewCard.tsx b/web/src/components/card/ReviewCard.tsx
index 09929cec5..6b8b6bb52 100644
--- a/web/src/components/card/ReviewCard.tsx
+++ b/web/src/components/card/ReviewCard.tsx
@@ -6,7 +6,7 @@ import { getIconForLabel } from "@/utils/iconUtil";
import { isDesktop, isIOS, isSafari } from "react-device-detect";
import useSWR from "swr";
import TimeAgo from "../dynamic/TimeAgo";
-import { useCallback, useMemo, useRef, useState } from "react";
+import { useCallback, useRef, useState } from "react";
import useImageLoaded from "@/hooks/use-image-loaded";
import ImageLoadingIndicator from "../indicators/ImageLoadingIndicator";
import { FaCompactDisc } from "react-icons/fa";
@@ -33,18 +33,23 @@ import axios from "axios";
import { toast } from "sonner";
import useKeyboardListener from "@/hooks/use-keyboard-listener";
import { Tooltip, TooltipContent, TooltipTrigger } from "../ui/tooltip";
-import { capitalizeFirstLetter } from "@/utils/stringUtil";
-import { buttonVariants } from "../ui/button";
+import { Button, buttonVariants } from "../ui/button";
import { Trans, useTranslation } from "react-i18next";
+import { cn } from "@/lib/utils";
+import { LuCircle } from "react-icons/lu";
+import { MdAutoAwesome } from "react-icons/md";
+import { GenAISummaryDialog } from "../overlay/chip/GenAISummaryChip";
+import { getTranslatedLabel } from "@/utils/i18n";
+import { formatList } from "@/utils/stringUtil";
type ReviewCardProps = {
event: ReviewSegment;
- currentTime: number;
+ activeReviewItem?: ReviewSegment;
onClick?: () => void;
};
export default function ReviewCard({
event,
- currentTime,
+ activeReviewItem,
onClick,
}: ReviewCardProps) {
const { t } = useTranslation(["components/dialog"]);
@@ -57,12 +62,6 @@ export default function ReviewCard({
: t("time.formattedTimestampHourMinute.12hour", { ns: "common" }),
config?.ui.timezone,
);
- const isSelected = useMemo(
- () =>
- event.start_time <= currentTime &&
- (event.end_time ?? Date.now() / 1000) >= currentTime,
- [event, currentTime],
- );
const [optionsOpen, setOptionsOpen] = useState(false);
const [deleteDialogOpen, setDeleteDialogOpen] = useState(false);
@@ -88,6 +87,11 @@ export default function ReviewCard({
if (response.status == 200) {
toast.success(t("export.toast.success"), {
position: "top-center",
+ action: (
+
+
+
+ ),
});
}
})
@@ -109,6 +113,7 @@ export default function ReviewCard({
useKeyboardListener(["Shift"], (_, modifiers) => {
bypassDialogRef.current = modifiers.shift;
+ return false;
});
const handleDelete = useCallback(() => {
@@ -119,6 +124,12 @@ export default function ReviewCard({
}
}, [bypassDialogRef, onDelete]);
+ const getEventType = (text: string) => {
+ if (event.data.sub_labels?.includes(text)) return "manual";
+ if (event.data.audio.includes(text)) return "audio";
+ return "object";
+ };
+
const content = (
-
- <>
- {event.data.objects.map((object) => {
- return getIconForLabel(
- object,
- "size-3 text-primary dark:text-white",
- );
- })}
- {event.data.audio.map((audio) => {
- return getIconForLabel(
- audio,
- "size-3 text-primary dark:text-white",
- );
- })}
- >
+
+
+
+ {event.data.objects.map((object, idx) => (
+
+ {getIconForLabel(object, "object", "size-3 text-white")}
+
+ ))}
+ {event.data.audio.map((audio, idx) => (
+
+ {getIconForLabel(audio, "audio", "size-3 text-white")}
+
+ ))}
+
{formattedDate}
- {[
- ...new Set([
- ...(event.data.objects || []),
- ...(event.data.sub_labels || []),
- ...(event.data.audio || []),
- ]),
- ]
- .filter(
- (item) => item !== undefined && !item.includes("-verified"),
- )
- .map((text) => capitalizeFirstLetter(text))
- .sort()
- .join(", ")
- .replaceAll("-verified", "")}
+ {formatList(
+ [
+ ...new Set([
+ ...(event.data.objects || []),
+ ...(event.data.sub_labels || []),
+ ...(event.data.audio || []),
+ ]),
+ ]
+ .filter(
+ (item) => item !== undefined && !item.includes("-verified"),
+ )
+ .map((text) => getTranslatedLabel(text, getEventType(text)))
+ .sort(),
+ )}
+ {event.data.metadata?.title && (
+
+
+
+
+ {event.data.metadata.title}
+
+
+
+ )}
);
diff --git a/web/src/components/card/SearchThumbnail.tsx b/web/src/components/card/SearchThumbnail.tsx
index 3876a7710..66f58f4fd 100644
--- a/web/src/components/card/SearchThumbnail.tsx
+++ b/web/src/components/card/SearchThumbnail.tsx
@@ -133,7 +133,11 @@ export default function SearchThumbnail({
className={`z-0 flex items-center justify-between gap-1 space-x-1 bg-gray-500 bg-gradient-to-br from-gray-400 to-gray-500 text-xs capitalize`}
onClick={() => onClick(searchResult, false, true)}
>
- {getIconForLabel(objectLabel, "size-3 text-white")}
+ {getIconForLabel(
+ objectLabel,
+ searchResult.data.type,
+ "size-3 text-white",
+ )}
{Math.floor(
(searchResult.data.score ??
searchResult.data.top_score ??
@@ -150,7 +154,9 @@ export default function SearchThumbnail({
.filter(
(item) => item !== undefined && !item.includes("-verified"),
)
- .map((text) => getTranslatedLabel(text))
+ .map((text) =>
+ getTranslatedLabel(text, searchResult.data.type),
+ )
.sort()
.join(", ")
.replaceAll("-verified", "")}
diff --git a/web/src/components/card/SearchThumbnailFooter.tsx b/web/src/components/card/SearchThumbnailFooter.tsx
index c86e9c3c6..808ad2831 100644
--- a/web/src/components/card/SearchThumbnailFooter.tsx
+++ b/web/src/components/card/SearchThumbnailFooter.tsx
@@ -13,8 +13,8 @@ type SearchThumbnailProps = {
columns: number;
findSimilar: () => void;
refreshResults: () => void;
- showObjectLifecycle: () => void;
- showSnapshot: () => void;
+ showTrackingDetails: () => void;
+ addTrigger: () => void;
};
export default function SearchThumbnailFooter({
@@ -22,8 +22,8 @@ export default function SearchThumbnailFooter({
columns,
findSimilar,
refreshResults,
- showObjectLifecycle,
- showSnapshot,
+ showTrackingDetails,
+ addTrigger,
}: SearchThumbnailProps) {
const { t } = useTranslation(["views/search"]);
const { data: config } = useSWR("config");
@@ -40,11 +40,11 @@ export default function SearchThumbnailFooter({
return (
4 && "items-start sm:flex-col lg:flex-row lg:items-center",
)}
>
-
+
{searchResult.end_time ? (
) : (
@@ -59,8 +59,8 @@ export default function SearchThumbnailFooter({
searchResult={searchResult}
findSimilar={findSimilar}
refreshResults={refreshResults}
- showObjectLifecycle={showObjectLifecycle}
- showSnapshot={showSnapshot}
+ showTrackingDetails={showTrackingDetails}
+ addTrigger={addTrigger}
/>
diff --git a/web/src/components/classification/ClassificationModelEditDialog.tsx b/web/src/components/classification/ClassificationModelEditDialog.tsx
new file mode 100644
index 000000000..77b0780f7
--- /dev/null
+++ b/web/src/components/classification/ClassificationModelEditDialog.tsx
@@ -0,0 +1,549 @@
+import { Button } from "@/components/ui/button";
+import {
+ Dialog,
+ DialogContent,
+ DialogDescription,
+ DialogHeader,
+ DialogTitle,
+} from "@/components/ui/dialog";
+import {
+ Form,
+ FormControl,
+ FormField,
+ FormItem,
+ FormLabel,
+ FormMessage,
+} from "@/components/ui/form";
+import { Input } from "@/components/ui/input";
+import { Label } from "@/components/ui/label";
+import { RadioGroup, RadioGroupItem } from "@/components/ui/radio-group";
+import {
+ Select,
+ SelectContent,
+ SelectItem,
+ SelectTrigger,
+ SelectValue,
+} from "@/components/ui/select";
+import {
+ CustomClassificationModelConfig,
+ FrigateConfig,
+} from "@/types/frigateConfig";
+import { ClassificationDatasetResponse } from "@/types/classification";
+import { getTranslatedLabel } from "@/utils/i18n";
+import { zodResolver } from "@hookform/resolvers/zod";
+import axios from "axios";
+import { useCallback, useEffect, useMemo, useState } from "react";
+import { useForm } from "react-hook-form";
+import { useTranslation } from "react-i18next";
+import { LuPlus, LuX } from "react-icons/lu";
+import { toast } from "sonner";
+import useSWR, { mutate } from "swr";
+import { z } from "zod";
+
+type ClassificationModelEditDialogProps = {
+ open: boolean;
+ model: CustomClassificationModelConfig;
+ onClose: () => void;
+ onSuccess: () => void;
+};
+
+type ObjectClassificationType = "sub_label" | "attribute";
+
+type ObjectFormData = {
+ objectLabel: string;
+ objectType: ObjectClassificationType;
+};
+
+type StateFormData = {
+ classes: string[];
+};
+
+export default function ClassificationModelEditDialog({
+ open,
+ model,
+ onClose,
+ onSuccess,
+}: ClassificationModelEditDialogProps) {
+ const { t } = useTranslation(["views/classificationModel"]);
+ const { data: config } = useSWR("config");
+ const [isSaving, setIsSaving] = useState(false);
+
+ const isStateModel = model.state_config !== undefined;
+ const isObjectModel = model.object_config !== undefined;
+
+ const objectLabels = useMemo(() => {
+ if (!config) return [];
+
+ const labels = new Set();
+
+ Object.values(config.cameras).forEach((cameraConfig) => {
+ if (!cameraConfig.enabled || !cameraConfig.enabled_in_config) {
+ return;
+ }
+
+ cameraConfig.objects.track.forEach((label) => {
+ if (!config.model.all_attributes.includes(label)) {
+ labels.add(label);
+ }
+ });
+ });
+
+ return [...labels].sort();
+ }, [config]);
+
+ // Define form schema based on model type
+ const formSchema = useMemo(() => {
+ if (isObjectModel) {
+ return z.object({
+ objectLabel: z
+ .string()
+ .min(1, t("wizard.step1.errors.objectLabelRequired")),
+ objectType: z.enum(["sub_label", "attribute"]),
+ });
+ } else {
+ // State model
+ return z.object({
+ classes: z
+ .array(z.string())
+ .min(1, t("wizard.step1.errors.classRequired"))
+ .refine(
+ (classes) => {
+ const nonEmpty = classes.filter((c) => c.trim().length > 0);
+ return nonEmpty.length >= 2;
+ },
+ { message: t("wizard.step1.errors.stateRequiresTwoClasses") },
+ )
+ .refine(
+ (classes) => {
+ const nonEmpty = classes.filter((c) => c.trim().length > 0);
+ const unique = new Set(nonEmpty.map((c) => c.toLowerCase()));
+ return unique.size === nonEmpty.length;
+ },
+ { message: t("wizard.step1.errors.classesUnique") },
+ ),
+ });
+ }
+ }, [isObjectModel, t]);
+
+ const form = useForm({
+ resolver: zodResolver(formSchema),
+ defaultValues: isObjectModel
+ ? ({
+ objectLabel: model.object_config?.objects?.[0] || "",
+ objectType:
+ (model.object_config
+ ?.classification_type as ObjectClassificationType) || "sub_label",
+ } as ObjectFormData)
+ : ({
+ classes: [""], // Will be populated from dataset
+ } as StateFormData),
+ mode: "onChange",
+ });
+
+ // Fetch dataset to get current classes for state models
+ const { data: dataset, mutate: mutateDataset } =
+ useSWR(
+ isStateModel && open ? `classification/${model.name}/dataset` : null,
+ { revalidateOnFocus: false },
+ );
+
+ useEffect(() => {
+ if (open) {
+ if (isObjectModel) {
+ form.reset({
+ objectLabel: model.object_config?.objects?.[0] || "",
+ objectType:
+ (model.object_config
+ ?.classification_type as ObjectClassificationType) || "sub_label",
+ } as ObjectFormData);
+ } else {
+ form.reset({
+ classes: [""],
+ } as StateFormData);
+ }
+
+ if (isStateModel) {
+ mutateDataset();
+ }
+ }
+ }, [open, isObjectModel, isStateModel, model, form, mutateDataset]);
+
+ // Update form with classes from dataset when loaded
+ useEffect(() => {
+ if (isStateModel && open && dataset?.categories) {
+ const classes = Object.keys(dataset.categories).filter(
+ (key) => key !== "none",
+ );
+ if (classes.length > 0) {
+ (form as ReturnType>).setValue(
+ "classes",
+ classes,
+ );
+ }
+ }
+ }, [dataset, isStateModel, open, form]);
+
+ const watchedClasses = isStateModel
+ ? (form as ReturnType>).watch("classes")
+ : undefined;
+ const watchedObjectType = isObjectModel
+ ? (form as ReturnType>).watch("objectType")
+ : undefined;
+
+ const handleAddClass = useCallback(() => {
+ const currentClasses = (
+ form as ReturnType>
+ ).getValues("classes");
+ (form as ReturnType>).setValue(
+ "classes",
+ [...currentClasses, ""],
+ {
+ shouldValidate: true,
+ },
+ );
+ }, [form]);
+
+ const handleRemoveClass = useCallback(
+ (index: number) => {
+ const currentClasses = (
+ form as ReturnType>
+ ).getValues("classes");
+ const newClasses = currentClasses.filter((_, i) => i !== index);
+
+ // Ensure at least one field remains (even if empty)
+ if (newClasses.length === 0) {
+ (form as ReturnType>).setValue(
+ "classes",
+ [""],
+ { shouldValidate: true },
+ );
+ } else {
+ (form as ReturnType>).setValue(
+ "classes",
+ newClasses,
+ { shouldValidate: true },
+ );
+ }
+ },
+ [form],
+ );
+
+ const onSubmit = useCallback(
+ async (data: ObjectFormData | StateFormData) => {
+ setIsSaving(true);
+ try {
+ if (isObjectModel) {
+ const objectData = data as ObjectFormData;
+
+ // Update the config
+ await axios.put("/config/set", {
+ requires_restart: 0,
+ update_topic: `config/classification/custom/${model.name}`,
+ config_data: {
+ classification: {
+ custom: {
+ [model.name]: {
+ enabled: model.enabled,
+ name: model.name,
+ threshold: model.threshold,
+ object_config: {
+ objects: [objectData.objectLabel],
+ classification_type: objectData.objectType,
+ },
+ },
+ },
+ },
+ },
+ });
+
+ toast.success(t("toast.success.updatedModel"), {
+ position: "top-center",
+ });
+ } else {
+ const stateData = data as StateFormData;
+ const newClasses = stateData.classes.filter(
+ (c) => c.trim().length > 0,
+ );
+ const oldClasses = dataset?.categories
+ ? Object.keys(dataset.categories).filter((key) => key !== "none")
+ : [];
+
+ const renameMap = new Map();
+ const maxLength = Math.max(oldClasses.length, newClasses.length);
+
+ for (let i = 0; i < maxLength; i++) {
+ const oldClass = oldClasses[i];
+ const newClass = newClasses[i];
+
+ if (oldClass && newClass && oldClass !== newClass) {
+ renameMap.set(oldClass, newClass);
+ }
+ }
+
+ const renamePromises = Array.from(renameMap.entries()).map(
+ async ([oldName, newName]) => {
+ try {
+ await axios.put(
+ `/classification/${model.name}/dataset/${oldName}/rename`,
+ {
+ new_category: newName,
+ },
+ );
+ } catch (err) {
+ const error = err as {
+ response?: { data?: { message?: string; detail?: string } };
+ };
+ const errorMessage =
+ error.response?.data?.message ||
+ error.response?.data?.detail ||
+ "Unknown error";
+ throw new Error(
+ `Failed to rename ${oldName} to ${newName}: ${errorMessage}`,
+ );
+ }
+ },
+ );
+
+ if (renamePromises.length > 0) {
+ await Promise.all(renamePromises);
+ await mutate(`classification/${model.name}/dataset`);
+ toast.success(t("toast.success.updatedModel"), {
+ position: "top-center",
+ });
+ } else {
+ toast.info(t("edit.stateClassesInfo"), {
+ position: "top-center",
+ });
+ }
+ }
+
+ onSuccess();
+ onClose();
+ } catch (err) {
+ const error = err as {
+ response?: { data?: { message?: string; detail?: string } };
+ message?: string;
+ };
+ const errorMessage =
+ error.message ||
+ error.response?.data?.message ||
+ error.response?.data?.detail ||
+ "Unknown error";
+ toast.error(t("toast.error.updateModelFailed", { errorMessage }), {
+ position: "top-center",
+ });
+ } finally {
+ setIsSaving(false);
+ }
+ },
+ [isObjectModel, model, dataset, t, onSuccess, onClose],
+ );
+
+ const handleCancel = useCallback(() => {
+ form.reset();
+ onClose();
+ }, [form, onClose]);
+
+ return (
+
+ );
+}
diff --git a/web/src/components/classification/ClassificationModelWizardDialog.tsx b/web/src/components/classification/ClassificationModelWizardDialog.tsx
new file mode 100644
index 000000000..0c43b9942
--- /dev/null
+++ b/web/src/components/classification/ClassificationModelWizardDialog.tsx
@@ -0,0 +1,223 @@
+import { useTranslation } from "react-i18next";
+import StepIndicator from "../indicators/StepIndicator";
+import {
+ Dialog,
+ DialogContent,
+ DialogDescription,
+ DialogHeader,
+ DialogTitle,
+} from "../ui/dialog";
+import { useReducer, useMemo } from "react";
+import Step1NameAndDefine, { Step1FormData } from "./wizard/Step1NameAndDefine";
+import Step2StateArea, { Step2FormData } from "./wizard/Step2StateArea";
+import Step3ChooseExamples, {
+ Step3FormData,
+} from "./wizard/Step3ChooseExamples";
+import { cn } from "@/lib/utils";
+import { isDesktop } from "react-device-detect";
+import axios from "axios";
+
+const OBJECT_STEPS = [
+ "wizard.steps.nameAndDefine",
+ "wizard.steps.chooseExamples",
+];
+
+const STATE_STEPS = [
+ "wizard.steps.nameAndDefine",
+ "wizard.steps.stateArea",
+ "wizard.steps.chooseExamples",
+];
+
+type ClassificationModelWizardDialogProps = {
+ open: boolean;
+ onClose: () => void;
+ defaultModelType?: "state" | "object";
+};
+
+type WizardState = {
+ currentStep: number;
+ step1Data?: Step1FormData;
+ step2Data?: Step2FormData;
+ step3Data?: Step3FormData;
+};
+
+type WizardAction =
+ | { type: "NEXT_STEP"; payload?: Partial }
+ | { type: "PREVIOUS_STEP" }
+ | { type: "SET_STEP_1"; payload: Step1FormData }
+ | { type: "SET_STEP_2"; payload: Step2FormData }
+ | { type: "SET_STEP_3"; payload: Step3FormData }
+ | { type: "RESET" };
+
+const initialState: WizardState = {
+ currentStep: 0,
+};
+
+function wizardReducer(state: WizardState, action: WizardAction): WizardState {
+ switch (action.type) {
+ case "SET_STEP_1":
+ return {
+ ...state,
+ step1Data: action.payload,
+ currentStep: 1,
+ };
+ case "SET_STEP_2":
+ return {
+ ...state,
+ step2Data: action.payload,
+ currentStep: 2,
+ };
+ case "SET_STEP_3":
+ return {
+ ...state,
+ step3Data: action.payload,
+ currentStep: 3,
+ };
+ case "NEXT_STEP":
+ return {
+ ...state,
+ ...action.payload,
+ currentStep: state.currentStep + 1,
+ };
+ case "PREVIOUS_STEP":
+ return {
+ ...state,
+ currentStep: Math.max(0, state.currentStep - 1),
+ };
+ case "RESET":
+ return initialState;
+ default:
+ return state;
+ }
+}
+
+export default function ClassificationModelWizardDialog({
+ open,
+ onClose,
+ defaultModelType,
+}: ClassificationModelWizardDialogProps) {
+ const { t } = useTranslation(["views/classificationModel"]);
+
+ const [wizardState, dispatch] = useReducer(wizardReducer, initialState);
+
+ const steps = useMemo(() => {
+ if (!wizardState.step1Data) {
+ return OBJECT_STEPS;
+ }
+ return wizardState.step1Data.modelType === "state"
+ ? STATE_STEPS
+ : OBJECT_STEPS;
+ }, [wizardState.step1Data]);
+
+ const handleStep1Next = (data: Step1FormData) => {
+ dispatch({ type: "SET_STEP_1", payload: data });
+ };
+
+ const handleStep2Next = (data: Step2FormData) => {
+ dispatch({ type: "SET_STEP_2", payload: data });
+ };
+
+ const handleBack = () => {
+ dispatch({ type: "PREVIOUS_STEP" });
+ };
+
+ const handleCancel = async () => {
+ // Clean up any generated training images if we're cancelling from Step 3
+ if (wizardState.step1Data && wizardState.step3Data?.examplesGenerated) {
+ try {
+ await axios.delete(
+ `/classification/${wizardState.step1Data.modelName}`,
+ );
+ } catch (error) {
+ // Silently fail - user is already cancelling
+ }
+ }
+
+ dispatch({ type: "RESET" });
+ onClose();
+ };
+
+ const handleSuccessClose = () => {
+ dispatch({ type: "RESET" });
+ onClose();
+ };
+
+ return (
+
+ );
+}
diff --git a/web/src/components/classification/wizard/Step1NameAndDefine.tsx b/web/src/components/classification/wizard/Step1NameAndDefine.tsx
new file mode 100644
index 000000000..a4cdc4867
--- /dev/null
+++ b/web/src/components/classification/wizard/Step1NameAndDefine.tsx
@@ -0,0 +1,508 @@
+import { Button } from "@/components/ui/button";
+import {
+ Form,
+ FormControl,
+ FormField,
+ FormItem,
+ FormLabel,
+ FormMessage,
+} from "@/components/ui/form";
+import { Input } from "@/components/ui/input";
+import { Label } from "@/components/ui/label";
+import { RadioGroup, RadioGroupItem } from "@/components/ui/radio-group";
+import {
+ Select,
+ SelectContent,
+ SelectItem,
+ SelectTrigger,
+ SelectValue,
+} from "@/components/ui/select";
+import { useForm } from "react-hook-form";
+import { zodResolver } from "@hookform/resolvers/zod";
+import { z } from "zod";
+import { useTranslation } from "react-i18next";
+import { useMemo } from "react";
+import { LuX, LuPlus, LuInfo, LuExternalLink } from "react-icons/lu";
+import useSWR from "swr";
+import { FrigateConfig } from "@/types/frigateConfig";
+import { getTranslatedLabel } from "@/utils/i18n";
+import { useDocDomain } from "@/hooks/use-doc-domain";
+import {
+ Popover,
+ PopoverContent,
+ PopoverTrigger,
+} from "@/components/ui/popover";
+
+export type ModelType = "state" | "object";
+export type ObjectClassificationType = "sub_label" | "attribute";
+
+export type Step1FormData = {
+ modelName: string;
+ modelType: ModelType;
+ objectLabel?: string;
+ objectType?: ObjectClassificationType;
+ classes: string[];
+};
+
+type Step1NameAndDefineProps = {
+ initialData?: Partial;
+ defaultModelType?: "state" | "object";
+ onNext: (data: Step1FormData) => void;
+ onCancel: () => void;
+};
+
+export default function Step1NameAndDefine({
+ initialData,
+ defaultModelType,
+ onNext,
+ onCancel,
+}: Step1NameAndDefineProps) {
+ const { t } = useTranslation(["views/classificationModel"]);
+ const { data: config } = useSWR("config");
+ const { getLocaleDocUrl } = useDocDomain();
+
+ const objectLabels = useMemo(() => {
+ if (!config) return [];
+
+ const labels = new Set();
+
+ Object.values(config.cameras).forEach((cameraConfig) => {
+ if (!cameraConfig.enabled || !cameraConfig.enabled_in_config) {
+ return;
+ }
+
+ cameraConfig.objects.track.forEach((label) => {
+ if (!config.model.all_attributes.includes(label)) {
+ labels.add(label);
+ }
+ });
+ });
+
+ return [...labels].sort();
+ }, [config]);
+
+ const step1FormData = z
+ .object({
+ modelName: z
+ .string()
+ .min(1, t("wizard.step1.errors.nameRequired"))
+ .max(64, t("wizard.step1.errors.nameLength"))
+ .refine((value) => !/^\d+$/.test(value), {
+ message: t("wizard.step1.errors.nameOnlyNumbers"),
+ }),
+ modelType: z.enum(["state", "object"]),
+ objectLabel: z.string().optional(),
+ objectType: z.enum(["sub_label", "attribute"]).optional(),
+ classes: z
+ .array(
+ z
+ .string()
+ .refine(
+ (val) => val.trim().toLowerCase() !== "none",
+ t("wizard.step1.errors.noneNotAllowed"),
+ ),
+ )
+ .min(1, t("wizard.step1.errors.classRequired"))
+ .refine(
+ (classes) => {
+ const nonEmpty = classes.filter((c) => c.trim().length > 0);
+ return nonEmpty.length >= 1;
+ },
+ { message: t("wizard.step1.errors.classRequired") },
+ )
+ .refine(
+ (classes) => {
+ const nonEmpty = classes.filter((c) => c.trim().length > 0);
+ const unique = new Set(nonEmpty.map((c) => c.toLowerCase()));
+ return unique.size === nonEmpty.length;
+ },
+ { message: t("wizard.step1.errors.classesUnique") },
+ ),
+ })
+ .refine(
+ (data) => {
+ // State models require at least 2 classes
+ if (data.modelType === "state") {
+ const nonEmpty = data.classes.filter((c) => c.trim().length > 0);
+ return nonEmpty.length >= 2;
+ }
+ return true;
+ },
+ {
+ message: t("wizard.step1.errors.stateRequiresTwoClasses"),
+ path: ["classes"],
+ },
+ )
+ .refine(
+ (data) => {
+ if (data.modelType === "object") {
+ return data.objectLabel !== undefined && data.objectLabel !== "";
+ }
+ return true;
+ },
+ {
+ message: t("wizard.step1.errors.objectLabelRequired"),
+ path: ["objectLabel"],
+ },
+ )
+ .refine(
+ (data) => {
+ if (data.modelType === "object") {
+ return data.objectType !== undefined;
+ }
+ return true;
+ },
+ {
+ message: t("wizard.step1.errors.objectTypeRequired"),
+ path: ["objectType"],
+ },
+ );
+
+ const form = useForm>({
+ resolver: zodResolver(step1FormData),
+ defaultValues: {
+ modelName: initialData?.modelName || "",
+ modelType: initialData?.modelType || defaultModelType || "state",
+ objectLabel: initialData?.objectLabel,
+ objectType: initialData?.objectType || "sub_label",
+ classes: initialData?.classes?.length ? initialData.classes : [""],
+ },
+ mode: "onChange",
+ });
+
+ const watchedClasses = form.watch("classes");
+ const watchedModelType = form.watch("modelType");
+ const watchedObjectType = form.watch("objectType");
+
+ const handleAddClass = () => {
+ const currentClasses = form.getValues("classes");
+ form.setValue("classes", [...currentClasses, ""], { shouldValidate: true });
+ };
+
+ const handleRemoveClass = (index: number) => {
+ const currentClasses = form.getValues("classes");
+ const newClasses = currentClasses.filter((_, i) => i !== index);
+
+ // Ensure at least one field remains (even if empty)
+ if (newClasses.length === 0) {
+ form.setValue("classes", [""], { shouldValidate: true });
+ } else {
+ form.setValue("classes", newClasses, { shouldValidate: true });
+ }
+ };
+
+ const onSubmit = (data: z.infer) => {
+ // Filter out empty classes
+ const filteredClasses = data.classes.filter((c) => c.trim().length > 0);
+ onNext({
+ ...data,
+ classes: filteredClasses,
+ });
+ };
+
+ return (
+
+
+
+
+
+
+
+
+
+ );
+}
diff --git a/web/src/components/classification/wizard/Step2StateArea.tsx b/web/src/components/classification/wizard/Step2StateArea.tsx
new file mode 100644
index 000000000..38c2fcad7
--- /dev/null
+++ b/web/src/components/classification/wizard/Step2StateArea.tsx
@@ -0,0 +1,479 @@
+import { Button } from "@/components/ui/button";
+import { useTranslation } from "react-i18next";
+import { useState, useMemo, useRef, useCallback, useEffect } from "react";
+import useSWR from "swr";
+import { FrigateConfig } from "@/types/frigateConfig";
+import {
+ Popover,
+ PopoverContent,
+ PopoverTrigger,
+} from "@/components/ui/popover";
+import { LuX, LuPlus } from "react-icons/lu";
+import { Stage, Layer, Rect, Transformer } from "react-konva";
+import Konva from "konva";
+import { useResizeObserver } from "@/hooks/resize-observer";
+import { useApiHost } from "@/api";
+import { resolveCameraName } from "@/hooks/use-camera-friendly-name";
+import Heading from "@/components/ui/heading";
+import { isMobile } from "react-device-detect";
+import { cn } from "@/lib/utils";
+
+export type CameraAreaConfig = {
+ camera: string;
+ crop: [number, number, number, number];
+};
+
+export type Step2FormData = {
+ cameraAreas: CameraAreaConfig[];
+};
+
+type Step2StateAreaProps = {
+ initialData?: Partial;
+ onNext: (data: Step2FormData) => void;
+ onBack: () => void;
+};
+
+export default function Step2StateArea({
+ initialData,
+ onNext,
+ onBack,
+}: Step2StateAreaProps) {
+ const { t } = useTranslation(["views/classificationModel"]);
+ const { data: config } = useSWR("config");
+ const apiHost = useApiHost();
+
+ const [cameraAreas, setCameraAreas] = useState(
+ initialData?.cameraAreas || [],
+ );
+ const [selectedCameraIndex, setSelectedCameraIndex] = useState(0);
+ const [isPopoverOpen, setIsPopoverOpen] = useState(false);
+ const [imageLoaded, setImageLoaded] = useState(false);
+
+ const containerRef = useRef(null);
+ const imageRef = useRef(null);
+ const stageRef = useRef(null);
+ const rectRef = useRef(null);
+ const transformerRef = useRef(null);
+
+ const [{ width: containerWidth }] = useResizeObserver(containerRef);
+
+ const availableCameras = useMemo(() => {
+ if (!config) return [];
+
+ const selectedCameraNames = cameraAreas.map((ca) => ca.camera);
+ return Object.entries(config.cameras)
+ .sort()
+ .filter(
+ ([name, cam]) =>
+ cam.enabled &&
+ cam.enabled_in_config &&
+ !selectedCameraNames.includes(name),
+ )
+ .map(([name]) => ({
+ name,
+ displayName: resolveCameraName(config, name),
+ }));
+ }, [config, cameraAreas]);
+
+ const selectedCamera = useMemo(() => {
+ if (cameraAreas.length === 0) return null;
+ return cameraAreas[selectedCameraIndex];
+ }, [cameraAreas, selectedCameraIndex]);
+
+ const selectedCameraConfig = useMemo(() => {
+ if (!config || !selectedCamera) return null;
+ return config.cameras[selectedCamera.camera];
+ }, [config, selectedCamera]);
+
+ const imageSize = useMemo(() => {
+ if (!containerWidth || !selectedCameraConfig) {
+ return { width: 0, height: 0 };
+ }
+
+ const containerAspectRatio = 16 / 9;
+ const containerHeight = containerWidth / containerAspectRatio;
+
+ const cameraAspectRatio =
+ selectedCameraConfig.detect.width / selectedCameraConfig.detect.height;
+
+ // Fit camera within 16:9 container
+ let imageWidth, imageHeight;
+ if (cameraAspectRatio > containerAspectRatio) {
+ imageWidth = containerWidth;
+ imageHeight = imageWidth / cameraAspectRatio;
+ } else {
+ imageHeight = containerHeight;
+ imageWidth = imageHeight * cameraAspectRatio;
+ }
+
+ return { width: imageWidth, height: imageHeight };
+ }, [containerWidth, selectedCameraConfig]);
+
+ const handleAddCamera = useCallback(
+ (cameraName: string) => {
+ // Calculate a square crop in pixel space
+ const camera = config?.cameras[cameraName];
+ if (!camera) return;
+
+ const cameraAspect = camera.detect.width / camera.detect.height;
+ const cropSize = 0.3;
+ let x1, y1, x2, y2;
+
+ if (cameraAspect >= 1) {
+ const pixelSize = cropSize * camera.detect.height;
+ const normalizedWidth = pixelSize / camera.detect.width;
+ x1 = (1 - normalizedWidth) / 2;
+ y1 = (1 - cropSize) / 2;
+ x2 = x1 + normalizedWidth;
+ y2 = y1 + cropSize;
+ } else {
+ const pixelSize = cropSize * camera.detect.width;
+ const normalizedHeight = pixelSize / camera.detect.height;
+ x1 = (1 - cropSize) / 2;
+ y1 = (1 - normalizedHeight) / 2;
+ x2 = x1 + cropSize;
+ y2 = y1 + normalizedHeight;
+ }
+
+ const newArea: CameraAreaConfig = {
+ camera: cameraName,
+ crop: [x1, y1, x2, y2],
+ };
+ setCameraAreas([...cameraAreas, newArea]);
+ setSelectedCameraIndex(cameraAreas.length);
+ setIsPopoverOpen(false);
+ },
+ [cameraAreas, config],
+ );
+
+ const handleRemoveCamera = useCallback(
+ (index: number) => {
+ const newAreas = cameraAreas.filter((_, i) => i !== index);
+ setCameraAreas(newAreas);
+ if (selectedCameraIndex >= newAreas.length) {
+ setSelectedCameraIndex(Math.max(0, newAreas.length - 1));
+ }
+ },
+ [cameraAreas, selectedCameraIndex],
+ );
+
+ const handleCropChange = useCallback(
+ (crop: [number, number, number, number]) => {
+ const newAreas = [...cameraAreas];
+ newAreas[selectedCameraIndex] = {
+ ...newAreas[selectedCameraIndex],
+ crop,
+ };
+ setCameraAreas(newAreas);
+ },
+ [cameraAreas, selectedCameraIndex],
+ );
+
+ useEffect(() => {
+ setImageLoaded(false);
+ }, [selectedCamera]);
+
+ useEffect(() => {
+ const rect = rectRef.current;
+ const transformer = transformerRef.current;
+
+ if (
+ rect &&
+ transformer &&
+ selectedCamera &&
+ imageSize.width > 0 &&
+ imageLoaded
+ ) {
+ rect.scaleX(1);
+ rect.scaleY(1);
+ transformer.nodes([rect]);
+ transformer.getLayer()?.batchDraw();
+ }
+ }, [selectedCamera, imageSize, imageLoaded]);
+
+ const handleRectChange = useCallback(() => {
+ const rect = rectRef.current;
+
+ if (rect && imageSize.width > 0) {
+ const actualWidth = rect.width() * rect.scaleX();
+ const actualHeight = rect.height() * rect.scaleY();
+
+ // Average dimensions to maintain perfect square
+ const size = (actualWidth + actualHeight) / 2;
+
+ rect.width(size);
+ rect.height(size);
+ rect.scaleX(1);
+ rect.scaleY(1);
+
+ const x1 = rect.x() / imageSize.width;
+ const y1 = rect.y() / imageSize.height;
+ const x2 = (rect.x() + size) / imageSize.width;
+ const y2 = (rect.y() + size) / imageSize.height;
+
+ handleCropChange([x1, y1, x2, y2]);
+ }
+ }, [imageSize, handleCropChange]);
+
+ const handleContinue = useCallback(() => {
+ onNext({ cameraAreas });
+ }, [cameraAreas, onNext]);
+
+ const canContinue = cameraAreas.length > 0;
+
+ return (
+
+
+
+
+ {t("wizard.step2.cameras")}
+ {availableCameras.length > 0 ? (
+
+
+
+
+ e.preventDefault()}
+ >
+
+
+ {t("wizard.step2.selectCamera")}
+
+
+ {availableCameras.map((cam) => (
+
+ ))}
+
+
+
+
+ ) : (
+
+ )}
+
+
+
+ {cameraAreas.map((area, index) => {
+ const isSelected = index === selectedCameraIndex;
+ const displayName = resolveCameraName(config, area.camera);
+
+ return (
+ setSelectedCameraIndex(index)}
+ >
+ {displayName}
+
+
+ );
+ })}
+
+
+ {cameraAreas.length === 0 && (
+
+ {t("wizard.step2.noCameras")}
+
+ )}
+
+
+
+
+ {selectedCamera && selectedCameraConfig && imageSize.width > 0 ? (
+
+
setImageLoaded(true)}
+ />
+
+
+ {
+ const rect = rectRef.current;
+ if (!rect) return pos;
+
+ const size = rect.width();
+ const x = Math.max(
+ 0,
+ Math.min(pos.x, imageSize.width - size),
+ );
+ const y = Math.max(
+ 0,
+ Math.min(pos.y, imageSize.height - size),
+ );
+
+ return { x, y };
+ }}
+ onDragEnd={handleRectChange}
+ onTransformEnd={handleRectChange}
+ />
+ {
+ const minSize = 50;
+ const maxSize = Math.min(
+ imageSize.width,
+ imageSize.height,
+ );
+
+ // Clamp dimensions to stage bounds first
+ const clampedWidth = Math.max(
+ minSize,
+ Math.min(newBox.width, maxSize),
+ );
+ const clampedHeight = Math.max(
+ minSize,
+ Math.min(newBox.height, maxSize),
+ );
+
+ // Enforce square using average
+ const size = (clampedWidth + clampedHeight) / 2;
+
+ // Clamp position to keep square within bounds
+ const x = Math.max(
+ 0,
+ Math.min(newBox.x, imageSize.width - size),
+ );
+ const y = Math.max(
+ 0,
+ Math.min(newBox.y, imageSize.height - size),
+ );
+
+ return {
+ ...newBox,
+ x,
+ y,
+ width: size,
+ height: size,
+ };
+ }}
+ />
+
+
+
+ ) : (
+
+ {t("wizard.step2.selectCameraPrompt")}
+
+ )}
+
+
+
+
+
+
+
+
+
+ );
+}
diff --git a/web/src/components/classification/wizard/Step3ChooseExamples.tsx b/web/src/components/classification/wizard/Step3ChooseExamples.tsx
new file mode 100644
index 000000000..e3dd04afc
--- /dev/null
+++ b/web/src/components/classification/wizard/Step3ChooseExamples.tsx
@@ -0,0 +1,628 @@
+import { Button } from "@/components/ui/button";
+import { useTranslation } from "react-i18next";
+import { useState, useEffect, useCallback, useMemo } from "react";
+import ActivityIndicator from "@/components/indicators/activity-indicator";
+import axios from "axios";
+import { toast } from "sonner";
+import { Step1FormData } from "./Step1NameAndDefine";
+import { Step2FormData } from "./Step2StateArea";
+import useSWR from "swr";
+import { baseUrl } from "@/api/baseUrl";
+import { isMobile } from "react-device-detect";
+import { cn } from "@/lib/utils";
+import { Alert, AlertDescription, AlertTitle } from "@/components/ui/alert";
+import { IoIosWarning } from "react-icons/io";
+
+export type Step3FormData = {
+ examplesGenerated: boolean;
+ imageClassifications?: { [imageName: string]: string };
+};
+
+type Step3ChooseExamplesProps = {
+ step1Data: Step1FormData;
+ step2Data?: Step2FormData;
+ initialData?: Partial;
+ onClose: () => void;
+ onBack: () => void;
+};
+
+export default function Step3ChooseExamples({
+ step1Data,
+ step2Data,
+ initialData,
+ onClose,
+ onBack,
+}: Step3ChooseExamplesProps) {
+ const { t } = useTranslation(["views/classificationModel"]);
+ const [isGenerating, setIsGenerating] = useState(false);
+ const [hasGenerated, setHasGenerated] = useState(
+ initialData?.examplesGenerated || false,
+ );
+ const [imageClassifications, setImageClassifications] = useState<{
+ [imageName: string]: string;
+ }>(initialData?.imageClassifications || {});
+ const [isTraining, setIsTraining] = useState(false);
+ const [isProcessing, setIsProcessing] = useState(false);
+ const [currentClassIndex, setCurrentClassIndex] = useState(0);
+ const [selectedImages, setSelectedImages] = useState>(new Set());
+ const [cacheKey, setCacheKey] = useState(Date.now());
+ const [loadedImages, setLoadedImages] = useState>(new Set());
+
+ const handleImageLoad = useCallback((imageName: string) => {
+ setLoadedImages((prev) => new Set(prev).add(imageName));
+ }, []);
+
+ const { data: trainImages, mutate: refreshTrainImages } = useSWR(
+ hasGenerated ? `classification/${step1Data.modelName}/train` : null,
+ );
+
+ const unknownImages = useMemo(() => {
+ if (!trainImages) return [];
+ return trainImages;
+ }, [trainImages]);
+
+ const toggleImageSelection = useCallback((imageName: string) => {
+ setSelectedImages((prev) => {
+ const newSet = new Set(prev);
+ if (newSet.has(imageName)) {
+ newSet.delete(imageName);
+ } else {
+ newSet.add(imageName);
+ }
+ return newSet;
+ });
+ }, []);
+
+ // Get all classes (excluding "none" - it will be auto-assigned)
+ const allClasses = useMemo(() => {
+ return [...step1Data.classes];
+ }, [step1Data.classes]);
+
+ const currentClass = allClasses[currentClassIndex];
+
+ const processClassificationsAndTrain = useCallback(
+ async (classifications: { [imageName: string]: string }) => {
+ // Step 1: Create config for the new model
+ const modelConfig: {
+ enabled: boolean;
+ name: string;
+ threshold: number;
+ state_config?: {
+ cameras: Record;
+ motion: boolean;
+ };
+ object_config?: { objects: string[]; classification_type: string };
+ } = {
+ enabled: true,
+ name: step1Data.modelName,
+ threshold: 0.8,
+ };
+
+ if (step1Data.modelType === "state") {
+ // State model config
+ const cameras: Record = {};
+ step2Data?.cameraAreas.forEach((area) => {
+ cameras[area.camera] = {
+ crop: area.crop,
+ };
+ });
+
+ modelConfig.state_config = {
+ cameras,
+ motion: true,
+ };
+ } else {
+ // Object model config
+ modelConfig.object_config = {
+ objects: step1Data.objectLabel ? [step1Data.objectLabel] : [],
+ classification_type: step1Data.objectType || "sub_label",
+ } as { objects: string[]; classification_type: string };
+ }
+
+ // Update config via config API
+ await axios.put("/config/set", {
+ requires_restart: 0,
+ update_topic: `config/classification/custom/${step1Data.modelName}`,
+ config_data: {
+ classification: {
+ custom: {
+ [step1Data.modelName]: modelConfig,
+ },
+ },
+ },
+ });
+
+ // Step 2: Classify each image by moving it to the correct category folder
+ const categorizePromises = Object.entries(classifications).map(
+ ([imageName, className]) => {
+ if (!className) return Promise.resolve();
+ return axios.post(
+ `/classification/${step1Data.modelName}/dataset/categorize`,
+ {
+ training_file: imageName,
+ category: className === "none" ? "none" : className,
+ },
+ );
+ },
+ );
+ await Promise.all(categorizePromises);
+
+ // Step 2.5: Delete any unselected images from train folder
+ // For state models, all images must be classified, so unselected images should be removed
+ // For object models, unselected images are assigned to "none" so they're already categorized
+ if (step1Data.modelType === "state") {
+ try {
+ // Fetch current train images to see what's left after categorization
+ const trainImagesResponse = await axios.get(
+ `/classification/${step1Data.modelName}/train`,
+ );
+ const remainingTrainImages = trainImagesResponse.data || [];
+
+ const categorizedImageNames = new Set(Object.keys(classifications));
+ const unselectedImages = remainingTrainImages.filter(
+ (imageName) => !categorizedImageNames.has(imageName),
+ );
+
+ if (unselectedImages.length > 0) {
+ await axios.post(
+ `/classification/${step1Data.modelName}/train/delete`,
+ {
+ ids: unselectedImages,
+ },
+ );
+ }
+ } catch (error) {
+ // Silently fail - unselected images will remain but won't cause issues
+ // since the frontend filters out images that don't match expected format
+ }
+ }
+
+ // Step 2.6: Create empty folders for classes that don't have any images
+ // This ensures all classes are available in the dataset view later
+ const classesWithImages = new Set(
+ Object.values(classifications).filter((c) => c && c !== "none"),
+ );
+ const emptyFolderPromises = step1Data.classes
+ .filter((className) => !classesWithImages.has(className))
+ .map((className) =>
+ axios.post(
+ `/classification/${step1Data.modelName}/dataset/${className}/create`,
+ ),
+ );
+ await Promise.all(emptyFolderPromises);
+
+ // Step 3: Determine if we should train
+ // For state models, we need ALL states to have examples (at least 2 states)
+ // For object models, we need at least 1 class with images (the rest go to "none")
+ const allStatesHaveExamplesForTraining =
+ step1Data.modelType !== "state" ||
+ step1Data.classes.every((className) =>
+ classesWithImages.has(className),
+ );
+ const shouldTrain =
+ step1Data.modelType === "object"
+ ? classesWithImages.size >= 1
+ : allStatesHaveExamplesForTraining && classesWithImages.size >= 2;
+
+ // Step 4: Kick off training only if we have enough classes with images
+ if (shouldTrain) {
+ await axios.post(`/classification/${step1Data.modelName}/train`);
+
+ toast.success(t("wizard.step3.trainingStarted"), {
+ closeButton: true,
+ });
+ setIsTraining(true);
+ } else {
+ // Don't train - not all states have examples
+ toast.success(t("wizard.step3.modelCreated"), {
+ closeButton: true,
+ });
+ setIsTraining(false);
+ onClose();
+ }
+ },
+ [step1Data, step2Data, t, onClose],
+ );
+
+ const handleContinueClassification = useCallback(async () => {
+ // Mark selected images with current class
+ const newClassifications = { ...imageClassifications };
+
+ // Handle user going back and de-selecting images
+ const imagesToCheck = unknownImages.slice(0, 24);
+ imagesToCheck.forEach((imageName) => {
+ if (
+ newClassifications[imageName] === currentClass &&
+ !selectedImages.has(imageName)
+ ) {
+ delete newClassifications[imageName];
+ }
+ });
+
+ // Then, add all currently selected images to the current class
+ selectedImages.forEach((imageName) => {
+ newClassifications[imageName] = currentClass;
+ });
+
+ // Check if we're on the last class to select
+ const isLastClass = currentClassIndex === allClasses.length - 1;
+
+ if (isLastClass) {
+ // For object models, assign remaining unclassified images to "none"
+ // For state models, this should never happen since we require all images to be classified
+ if (step1Data.modelType !== "state") {
+ unknownImages.slice(0, 24).forEach((imageName) => {
+ if (!newClassifications[imageName]) {
+ newClassifications[imageName] = "none";
+ }
+ });
+ }
+
+ // All done, trigger training immediately
+ setImageClassifications(newClassifications);
+ setIsProcessing(true);
+
+ try {
+ await processClassificationsAndTrain(newClassifications);
+ } catch (error) {
+ const axiosError = error as {
+ response?: { data?: { message?: string; detail?: string } };
+ message?: string;
+ };
+ const errorMessage =
+ axiosError.response?.data?.message ||
+ axiosError.response?.data?.detail ||
+ axiosError.message ||
+ "Failed to classify images";
+
+ toast.error(
+ t("wizard.step3.errors.classifyFailed", { error: errorMessage }),
+ );
+ setIsProcessing(false);
+ }
+ } else {
+ // Move to next class
+ setImageClassifications(newClassifications);
+ setCurrentClassIndex((prev) => prev + 1);
+ setSelectedImages(new Set());
+ }
+ }, [
+ selectedImages,
+ currentClass,
+ currentClassIndex,
+ allClasses,
+ imageClassifications,
+ unknownImages,
+ step1Data,
+ processClassificationsAndTrain,
+ t,
+ ]);
+
+ const generateExamples = useCallback(async () => {
+ setIsGenerating(true);
+
+ try {
+ if (step1Data.modelType === "state") {
+ // For state models, use cameras and crop areas
+ if (!step2Data?.cameraAreas || step2Data.cameraAreas.length === 0) {
+ toast.error(t("wizard.step3.errors.noCameras"));
+ setIsGenerating(false);
+ return;
+ }
+
+ const cameras: { [key: string]: [number, number, number, number] } = {};
+ step2Data.cameraAreas.forEach((area) => {
+ cameras[area.camera] = area.crop;
+ });
+
+ await axios.post("/classification/generate_examples/state", {
+ model_name: step1Data.modelName,
+ cameras,
+ });
+ } else {
+ // For object models, use label
+ if (!step1Data.objectLabel) {
+ toast.error(t("wizard.step3.errors.noObjectLabel"));
+ setIsGenerating(false);
+ return;
+ }
+
+ // For now, use all enabled cameras
+ // TODO: In the future, we might want to let users select specific cameras
+ await axios.post("/classification/generate_examples/object", {
+ model_name: step1Data.modelName,
+ label: step1Data.objectLabel,
+ });
+ }
+
+ setHasGenerated(true);
+ toast.success(t("wizard.step3.generateSuccess"));
+
+ // Update cache key to force image reload
+ setCacheKey(Date.now());
+ await refreshTrainImages();
+ } catch (error) {
+ const axiosError = error as {
+ response?: { data?: { message?: string; detail?: string } };
+ message?: string;
+ };
+ const errorMessage =
+ axiosError.response?.data?.message ||
+ axiosError.response?.data?.detail ||
+ axiosError.message ||
+ "Failed to generate examples";
+
+ toast.error(
+ t("wizard.step3.errors.generateFailed", { error: errorMessage }),
+ );
+ } finally {
+ setIsGenerating(false);
+ }
+ }, [step1Data, step2Data, t, refreshTrainImages]);
+
+ useEffect(() => {
+ if (!hasGenerated && !isGenerating) {
+ generateExamples();
+ }
+ // eslint-disable-next-line react-hooks/exhaustive-deps
+ }, []);
+
+ const handleContinue = useCallback(async () => {
+ setIsProcessing(true);
+ try {
+ await processClassificationsAndTrain(imageClassifications);
+ } catch (error) {
+ const axiosError = error as {
+ response?: { data?: { message?: string; detail?: string } };
+ message?: string;
+ };
+ const errorMessage =
+ axiosError.response?.data?.message ||
+ axiosError.response?.data?.detail ||
+ axiosError.message ||
+ "Failed to classify images";
+
+ toast.error(
+ t("wizard.step3.errors.classifyFailed", { error: errorMessage }),
+ );
+ setIsProcessing(false);
+ }
+ }, [imageClassifications, processClassificationsAndTrain, t]);
+
+ const unclassifiedImages = useMemo(() => {
+ if (!unknownImages) return [];
+ const images = unknownImages.slice(0, 24);
+
+ // Only filter if we have any classifications
+ if (Object.keys(imageClassifications).length === 0) {
+ return images;
+ }
+
+ // If we're viewing a previous class (going back), show images for that class
+ // Otherwise show only unclassified images
+ const currentClassInView = allClasses[currentClassIndex];
+ return images.filter((img) => {
+ const imgClass = imageClassifications[img];
+ // Show if: unclassified OR classified with current class we're viewing
+ return !imgClass || imgClass === currentClassInView;
+ });
+ }, [unknownImages, imageClassifications, allClasses, currentClassIndex]);
+
+ const allImagesClassified = useMemo(() => {
+ return unclassifiedImages.length === 0;
+ }, [unclassifiedImages]);
+
+ const isLastClass = currentClassIndex === allClasses.length - 1;
+ const statesWithExamples = useMemo(() => {
+ if (step1Data.modelType !== "state") return new Set();
+
+ const states = new Set();
+ const allImages = unknownImages.slice(0, 24);
+
+ // Check which states have at least one image classified
+ allImages.forEach((img) => {
+ let className: string | undefined;
+ if (selectedImages.has(img)) {
+ className = currentClass;
+ } else {
+ className = imageClassifications[img];
+ }
+ if (className && allClasses.includes(className)) {
+ states.add(className);
+ }
+ });
+
+ return states;
+ }, [
+ step1Data.modelType,
+ unknownImages,
+ imageClassifications,
+ selectedImages,
+ currentClass,
+ allClasses,
+ ]);
+
+ const allStatesHaveExamples = useMemo(() => {
+ if (step1Data.modelType !== "state") return true;
+ return allClasses.every((className) => statesWithExamples.has(className));
+ }, [step1Data.modelType, allClasses, statesWithExamples]);
+
+ const hasUnclassifiedImages = useMemo(() => {
+ if (!unknownImages) return false;
+ const allImages = unknownImages.slice(0, 24);
+ return allImages.some((img) => !imageClassifications[img]);
+ }, [unknownImages, imageClassifications]);
+
+ const showMissingStatesWarning = useMemo(() => {
+ return (
+ step1Data.modelType === "state" &&
+ isLastClass &&
+ !allStatesHaveExamples &&
+ !hasUnclassifiedImages &&
+ hasGenerated
+ );
+ }, [
+ step1Data.modelType,
+ isLastClass,
+ allStatesHaveExamples,
+ hasUnclassifiedImages,
+ hasGenerated,
+ ]);
+
+ const handleBack = useCallback(() => {
+ if (currentClassIndex > 0) {
+ const previousClass = allClasses[currentClassIndex - 1];
+ setCurrentClassIndex((prev) => prev - 1);
+
+ // Restore selections for the previous class
+ const previousSelections = Object.entries(imageClassifications)
+ .filter(([_, className]) => className === previousClass)
+ .map(([imageName, _]) => imageName);
+ setSelectedImages(new Set(previousSelections));
+ } else {
+ onBack();
+ }
+ }, [currentClassIndex, allClasses, imageClassifications, onBack]);
+
+ return (
+
+ {isTraining ? (
+
+
+
+
+ {t("wizard.step3.training.title")}
+
+
+ {t("wizard.step3.training.description")}
+
+
+
+
+ ) : isGenerating ? (
+
+
+
+
+ {t("wizard.step3.generating.title")}
+
+
+ {t("wizard.step3.generating.description")}
+
+
+
+ ) : hasGenerated ? (
+
+ {showMissingStatesWarning && (
+
+
+
+ {t("wizard.step3.missingStatesWarning.title")}
+
+
+ {t("wizard.step3.missingStatesWarning.description")}
+
+
+ )}
+ {!allImagesClassified && (
+
+
+ {t("wizard.step3.selectImagesPrompt", {
+ className: currentClass,
+ })}
+
+
+ {t("wizard.step3.selectImagesDescription")}
+
+
+ )}
+
+ {!unknownImages || unknownImages.length === 0 ? (
+
+
+ {t("wizard.step3.noImages")}
+
+
+
+ ) : allImagesClassified && isProcessing ? (
+
+
+
+ {t("wizard.step3.classifying")}
+
+
+ ) : (
+
+ {unclassifiedImages.map((imageName, index) => {
+ const isSelected = selectedImages.has(imageName);
+ return (
+ toggleImageSelection(imageName)}
+ >
+ {!loadedImages.has(imageName) && (
+
+
+
+ )}
+
handleImageLoad(imageName)}
+ />
+
+ );
+ })}
+
+ )}
+
+
+ ) : (
+
+
+ {t("wizard.step3.errors.generationFailed")}
+
+
+
+ )}
+
+ {!isTraining && (
+
+
+
+
+ )}
+
+ );
+}
diff --git a/web/src/components/dynamic/CameraFeatureToggle.tsx b/web/src/components/dynamic/CameraFeatureToggle.tsx
index 122178edb..5479e4297 100644
--- a/web/src/components/dynamic/CameraFeatureToggle.tsx
+++ b/web/src/components/dynamic/CameraFeatureToggle.tsx
@@ -6,6 +6,7 @@ import {
} from "@/components/ui/tooltip";
import { isDesktop } from "react-device-detect";
import { cn } from "@/lib/utils";
+import ActivityIndicator from "../indicators/activity-indicator";
const variants = {
primary: {
@@ -30,7 +31,8 @@ type CameraFeatureToggleProps = {
Icon: IconType;
title: string;
onClick?: () => void;
- disabled?: boolean; // New prop for disabling
+ disabled?: boolean;
+ loading?: boolean;
};
export default function CameraFeatureToggle({
@@ -40,7 +42,8 @@ export default function CameraFeatureToggle({
Icon,
title,
onClick,
- disabled = false, // Default to false
+ disabled = false,
+ loading = false,
}: CameraFeatureToggleProps) {
const content = (
-
+ {loading ? (
+
+ ) : (
+
+ )}
);
diff --git a/web/src/components/filter/CalendarFilterButton.tsx b/web/src/components/filter/CalendarFilterButton.tsx
index 876eb9ab0..9f052b73d 100644
--- a/web/src/components/filter/CalendarFilterButton.tsx
+++ b/web/src/components/filter/CalendarFilterButton.tsx
@@ -18,6 +18,7 @@ import PlatformAwareDialog from "../overlay/dialog/PlatformAwareDialog";
import { useTranslation } from "react-i18next";
import useSWR from "swr";
import { FrigateConfig } from "@/types/frigateConfig";
+import { useUserPersistence } from "@/hooks/use-user-persistence";
type CalendarFilterButtonProps = {
reviewSummary?: ReviewSummary;
@@ -105,6 +106,7 @@ export function CalendarRangeFilterButton({
const { t } = useTranslation(["components/filter"]);
const { data: config } = useSWR("config");
const timezone = useTimezone(config);
+ const [weekStartsOn] = useUserPersistence("weekStartsOn", 0);
const [open, setOpen] = useState(false);
const selectedDate = useFormattedRange(
@@ -138,6 +140,7 @@ export function CalendarRangeFilterButton({
initialDateTo={range?.to}
timezone={timezone}
showCompare={false}
+ weekStartsOn={weekStartsOn}
onUpdate={(range) => {
updateSelectedRange(range.range);
setOpen(false);
diff --git a/web/src/components/filter/CameraGroupSelector.tsx b/web/src/components/filter/CameraGroupSelector.tsx
index 6d9ea7856..14845fdb8 100644
--- a/web/src/components/filter/CameraGroupSelector.tsx
+++ b/web/src/components/filter/CameraGroupSelector.tsx
@@ -7,9 +7,8 @@ import {
import { isDesktop, isMobile } from "react-device-detect";
import useSWR from "swr";
import { MdHome } from "react-icons/md";
-import { usePersistedOverlayState } from "@/hooks/use-overlay-state";
import { Button, buttonVariants } from "../ui/button";
-import { useCallback, useMemo, useState } from "react";
+import { useCallback, useEffect, useMemo, useState } from "react";
import { Tooltip, TooltipContent, TooltipTrigger } from "../ui/tooltip";
import { LuPencil, LuPlus } from "react-icons/lu";
import {
@@ -57,7 +56,7 @@ import { Toaster } from "@/components/ui/sonner";
import { toast } from "sonner";
import ActivityIndicator from "../indicators/activity-indicator";
import { ScrollArea, ScrollBar } from "../ui/scroll-area";
-import { usePersistence } from "@/hooks/use-persistence";
+import { useUserPersistence } from "@/hooks/use-user-persistence";
import { TooltipPortal } from "@radix-ui/react-tooltip";
import { cn } from "@/lib/utils";
import * as LuIcons from "react-icons/lu";
@@ -71,12 +70,15 @@ import {
MobilePageTitle,
} from "../mobile/MobilePage";
-import { Label } from "../ui/label";
import { Switch } from "../ui/switch";
import { CameraStreamingDialog } from "../settings/CameraStreamingDialog";
import { DialogTrigger } from "@radix-ui/react-dialog";
import { useStreamingSettings } from "@/context/streaming-settings-provider";
import { Trans, useTranslation } from "react-i18next";
+import { CameraNameLabel } from "../camera/FriendlyNameLabel";
+import { useAllowedCameras } from "@/hooks/use-allowed-cameras";
+import { useIsAdmin } from "@/hooks/use-is-admin";
+import { useUserPersistedOverlayState } from "@/hooks/use-overlay-state";
type CameraGroupSelectorProps = {
className?: string;
@@ -85,6 +87,8 @@ type CameraGroupSelectorProps = {
export function CameraGroupSelector({ className }: CameraGroupSelectorProps) {
const { t } = useTranslation(["components/camera"]);
const { data: config } = useSWR("config");
+ const allowedCameras = useAllowedCameras();
+ const isAdmin = useIsAdmin();
// tooltip
@@ -105,9 +109,9 @@ export function CameraGroupSelector({ className }: CameraGroupSelectorProps) {
[timeoutId],
);
- // groups
+ // groups - use user-namespaced key for persistence to avoid cross-user conflicts
- const [group, setGroup, deleteGroup] = usePersistedOverlayState(
+ const [group, setGroup, , deleteGroup] = useUserPersistedOverlayState(
"cameraGroup",
"default" as string,
);
@@ -117,10 +121,22 @@ export function CameraGroupSelector({ className }: CameraGroupSelectorProps) {
return [];
}
- return Object.entries(config.camera_groups).sort(
- (a, b) => a[1].order - b[1].order,
- );
- }, [config]);
+ const allGroups = Object.entries(config.camera_groups);
+
+ // If custom role, filter out groups where user has no accessible cameras
+ if (!isAdmin) {
+ return allGroups
+ .filter(([, groupConfig]) => {
+ // Check if user has access to at least one camera in this group
+ return groupConfig.cameras.some((cameraName) =>
+ allowedCameras.includes(cameraName),
+ );
+ })
+ .sort((a, b) => a[1].order - b[1].order);
+ }
+
+ return allGroups.sort((a, b) => a[1].order - b[1].order);
+ }, [config, allowedCameras, isAdmin]);
// add group
@@ -137,6 +153,7 @@ export function CameraGroupSelector({ className }: CameraGroupSelectorProps) {
activeGroup={group}
setGroup={setGroup}
deleteGroup={deleteGroup}
+ isAdmin={isAdmin}
/>
setAddGroup(true)}
- >
-
-
+ {isAdmin && (
+
+ )}
{isMobile && }
@@ -226,6 +245,7 @@ type NewGroupDialogProps = {
activeGroup?: string;
setGroup: (value: string | undefined, replace?: boolean | undefined) => void;
deleteGroup: () => void;
+ isAdmin?: boolean;
};
function NewGroupDialog({
open,
@@ -234,6 +254,7 @@ function NewGroupDialog({
activeGroup,
setGroup,
deleteGroup,
+ isAdmin,
}: NewGroupDialogProps) {
const { t } = useTranslation(["components/camera"]);
const { mutate: updateConfig } = useSWR("config");
@@ -255,10 +276,16 @@ function NewGroupDialog({
const [editState, setEditState] = useState<"none" | "add" | "edit">("none");
const [isLoading, setIsLoading] = useState(false);
- const [, , , deleteGridLayout] = usePersistence(
+ const [, , , deleteGridLayout] = useUserPersistence(
`${activeGroup}-draggable-layout`,
);
+ useEffect(() => {
+ if (!open) {
+ setEditState("none");
+ }
+ }, [open]);
+
// callbacks
const onDeleteGroup = useCallback(
@@ -347,13 +374,7 @@ function NewGroupDialog({
position="top-center"
closeButton={true}
/>
- {
- setEditState("none");
- setOpen(open);
- }}
- >
+
{t("group.label")}
{t("group.edit")}
-
-
-
+
+
+ )}
{currentGroups.map((group) => (
@@ -399,6 +422,7 @@ function NewGroupDialog({
group={group}
onDeleteGroup={() => onDeleteGroup(group[0])}
onEditGroup={() => onEditGroup(group)}
+ isReadOnly={!isAdmin}
/>
))}
@@ -510,12 +534,14 @@ type CameraGroupRowProps = {
group: [string, CameraGroupConfig];
onDeleteGroup: () => void;
onEditGroup: () => void;
+ isReadOnly?: boolean;
};
export function CameraGroupRow({
group,
onDeleteGroup,
onEditGroup,
+ isReadOnly,
}: CameraGroupRowProps) {
const { t } = useTranslation(["components/camera"]);
const [deleteDialogOpen, setDeleteDialogOpen] = useState(false);
@@ -562,7 +588,7 @@ export function CameraGroupRow({
- {isMobile && (
+ {isMobile && !isReadOnly && (
<>
@@ -587,7 +613,7 @@ export function CameraGroupRow({
>
)}
- {!isMobile && (
+ {!isMobile && !isReadOnly && (
@@ -650,6 +676,9 @@ export function CameraGroupEdit({
allGroupsStreamingSettings[editingGroup?.[0] ?? ""],
);
+ const allowedCameras = useAllowedCameras();
+ const isAdmin = useIsAdmin();
+
const [openCamera, setOpenCamera] = useState();
const birdseyeConfig = useMemo(() => config?.birdseye, [config]);
@@ -837,21 +866,25 @@ export function CameraGroupEdit({
{t("group.cameras.desc")}
{[
- ...(birdseyeConfig?.enabled ? ["birdseye"] : []),
- ...Object.keys(config?.cameras ?? {}).sort(
- (a, b) =>
- (config?.cameras[a]?.ui?.order ?? 0) -
- (config?.cameras[b]?.ui?.order ?? 0),
- ),
+ ...(birdseyeConfig?.enabled &&
+ (isAdmin || "birdseye" in allowedCameras)
+ ? ["birdseye"]
+ : []),
+ ...Object.keys(config?.cameras ?? {})
+ .filter((camera) => allowedCameras.includes(camera))
+ .sort(
+ (a, b) =>
+ (config?.cameras[a]?.ui?.order ?? 0) -
+ (config?.cameras[b]?.ui?.order ?? 0),
+ ),
].map((camera) => (
-
+ camera={camera}
+ />
{camera !== "birdseye" && (
diff --git a/web/src/components/filter/CamerasFilterButton.tsx b/web/src/components/filter/CamerasFilterButton.tsx
index 247555a0a..cc89e13cf 100644
--- a/web/src/components/filter/CamerasFilterButton.tsx
+++ b/web/src/components/filter/CamerasFilterButton.tsx
@@ -13,6 +13,7 @@ import { Drawer, DrawerContent, DrawerTrigger } from "../ui/drawer";
import FilterSwitch from "./FilterSwitch";
import { FaVideo } from "react-icons/fa";
import { useTranslation } from "react-i18next";
+import { useAllowedCameras } from "@/hooks/use-allowed-cameras";
type CameraFilterButtonProps = {
allCameras: string[];
@@ -35,6 +36,30 @@ export function CamerasFilterButton({
const [currentCameras, setCurrentCameras] = useState(
selectedCameras,
);
+ const allowedCameras = useAllowedCameras();
+
+ // Filter cameras to only include those the user has access to
+ const filteredCameras = useMemo(
+ () => allCameras.filter((camera) => allowedCameras.includes(camera)),
+ [allCameras, allowedCameras],
+ );
+
+ // Filter groups to only include those with at least one allowed camera
+ const filteredGroups = useMemo(
+ () =>
+ groups
+ .map(([name, config]) => {
+ const allowedGroupCameras = config.cameras.filter((camera) =>
+ allowedCameras.includes(camera),
+ );
+ return [name, { ...config, cameras: allowedGroupCameras }] as [
+ string,
+ CameraGroupConfig,
+ ];
+ })
+ .filter(([, config]) => config.cameras.length > 0),
+ [groups, allowedCameras],
+ );
const buttonText = useMemo(() => {
if (isMobile) {
@@ -79,8 +104,8 @@ export function CamerasFilterButton({
);
const content = (
void;
};
export default function FilterSwitch({
label,
disabled = false,
isChecked,
+ type = "",
+ extraValue = "",
onCheckedChange,
}: FilterSwitchProps) {
return (
-
+ {type === "camera" ? (
+
+ ) : type === "zone" ? (
+
+ ) : (
+
+ )}
void;
+ selectedReviews: ReviewSegment[];
+ setSelectedReviews: (reviews: ReviewSegment[]) => void;
onExport: (id: string) => void;
pullLatestData: () => void;
};
@@ -32,19 +34,29 @@ export default function ReviewActionGroup({
pullLatestData,
}: ReviewActionGroupProps) {
const { t } = useTranslation(["components/dialog"]);
+ const isAdmin = useIsAdmin();
const onClearSelected = useCallback(() => {
setSelectedReviews([]);
}, [setSelectedReviews]);
- const onMarkAsReviewed = useCallback(async () => {
- await axios.post(`reviews/viewed`, { ids: selectedReviews });
+ const allReviewed = selectedReviews.every(
+ (review) => review.has_been_reviewed,
+ );
+
+ const onToggleReviewed = useCallback(async () => {
+ const ids = selectedReviews.map((review) => review.id);
+ await axios.post(`reviews/viewed`, {
+ ids,
+ reviewed: !allReviewed,
+ });
setSelectedReviews([]);
pullLatestData();
- }, [selectedReviews, setSelectedReviews, pullLatestData]);
+ }, [selectedReviews, setSelectedReviews, pullLatestData, allReviewed]);
const onDelete = useCallback(() => {
+ const ids = selectedReviews.map((review) => review.id);
axios
- .post(`reviews/delete`, { ids: selectedReviews })
+ .post(`reviews/delete`, { ids })
.then((resp) => {
if (resp.status === 200) {
toast.success(t("recording.confirmDelete.toast.success"), {
@@ -75,6 +87,7 @@ export default function ReviewActionGroup({
useKeyboardListener(["Shift"], (_, modifiers) => {
setBypassDialog(modifiers.shift);
+ return false;
});
const handleDelete = useCallback(() => {
@@ -139,7 +152,7 @@ export default function ReviewActionGroup({
aria-label={t("recording.button.export")}
size="sm"
onClick={() => {
- onExport(selectedReviews[0]);
+ onExport(selectedReviews[0].id);
onClearSelected();
}}
>
@@ -153,32 +166,44 @@ export default function ReviewActionGroup({
)}
-
+ {isAdmin && (
+
+ )}
>
diff --git a/web/src/components/filter/ReviewFilterGroup.tsx b/web/src/components/filter/ReviewFilterGroup.tsx
index f2234b359..76274ec3f 100644
--- a/web/src/components/filter/ReviewFilterGroup.tsx
+++ b/web/src/components/filter/ReviewFilterGroup.tsx
@@ -25,6 +25,7 @@ import { CamerasFilterButton } from "./CamerasFilterButton";
import PlatformAwareDialog from "../overlay/dialog/PlatformAwareDialog";
import { useTranslation } from "react-i18next";
import { getTranslatedLabel } from "@/utils/i18n";
+import { useAllowedCameras } from "@/hooks/use-allowed-cameras";
const REVIEW_FILTERS = [
"cameras",
@@ -72,6 +73,7 @@ export default function ReviewFilterGroup({
setMotionOnly,
}: ReviewFilterGroupProps) {
const { data: config } = useSWR("config");
+ const allowedCameras = useAllowedCameras();
const allLabels = useMemo(() => {
if (filterList?.labels) {
@@ -83,7 +85,9 @@ export default function ReviewFilterGroup({
}
const labels = new Set();
- const cameras = filter?.cameras || Object.keys(config.cameras);
+ const cameras = (filter?.cameras || allowedCameras).filter((camera) =>
+ allowedCameras.includes(camera),
+ );
cameras.forEach((camera) => {
if (camera == "birdseye") {
@@ -106,7 +110,7 @@ export default function ReviewFilterGroup({
});
return [...labels].sort();
- }, [config, filterList, filter]);
+ }, [config, filterList, filter, allowedCameras]);
const allZones = useMemo(() => {
if (filterList?.zones) {
@@ -118,7 +122,9 @@ export default function ReviewFilterGroup({
}
const zones = new Set();
- const cameras = filter?.cameras || Object.keys(config.cameras);
+ const cameras = (filter?.cameras || allowedCameras).filter((camera) =>
+ allowedCameras.includes(camera),
+ );
cameras.forEach((camera) => {
if (camera == "birdseye") {
@@ -134,11 +140,11 @@ export default function ReviewFilterGroup({
});
return [...zones].sort();
- }, [config, filterList, filter]);
+ }, [config, filterList, filter, allowedCameras]);
const filterValues = useMemo(
() => ({
- cameras: Object.keys(config?.cameras ?? {}).sort(
+ cameras: allowedCameras.sort(
(a, b) =>
(config?.cameras[a]?.ui?.order ?? 0) -
(config?.cameras[b]?.ui?.order ?? 0),
@@ -146,7 +152,7 @@ export default function ReviewFilterGroup({
labels: Object.values(allLabels || {}),
zones: Object.values(allZones || {}),
}),
- [config, allLabels, allZones],
+ [config, allLabels, allZones, allowedCameras],
);
const groups = useMemo(() => {
@@ -448,6 +454,24 @@ export function GeneralFilterContent({
onClose,
}: GeneralFilterContentProps) {
const { t } = useTranslation(["components/filter", "views/events"]);
+ const { data: config } = useSWR("config", {
+ revalidateOnFocus: false,
+ });
+ const allAudioListenLabels = useMemo(() => {
+ if (!config) {
+ return [];
+ }
+
+ const labels = new Set();
+ Object.values(config.cameras).forEach((camera) => {
+ if (camera?.audio?.enabled) {
+ camera.audio.listen.forEach((label) => {
+ labels.add(label);
+ });
+ }
+ });
+ return [...labels].sort();
+ }, [config]);
return (
<>
@@ -489,8 +513,7 @@ export function GeneralFilterContent({
checked={filter.labels === undefined}
onCheckedChange={(isChecked) => {
if (isChecked) {
- const { labels: _labels, ...rest } = filter;
- onUpdateFilter(rest);
+ onUpdateFilter({ ...filter, labels: undefined });
}
}}
/>
@@ -499,7 +522,10 @@ export function GeneralFilterContent({
{allLabels.map((item) => (
{
if (isChecked) {
@@ -536,8 +562,7 @@ export function GeneralFilterContent({
checked={filter.zones === undefined}
onCheckedChange={(isChecked) => {
if (isChecked) {
- const { zones: _zones, ...rest } = filter;
- onUpdateFilter(rest);
+ onUpdateFilter({ ...filter, zones: undefined });
}
}}
/>
@@ -546,7 +571,8 @@ export function GeneralFilterContent({
{allZones.map((item) => (
{
if (isChecked) {
diff --git a/web/src/components/filter/SearchActionGroup.tsx b/web/src/components/filter/SearchActionGroup.tsx
index ad6d6ccc8..62a3dc648 100644
--- a/web/src/components/filter/SearchActionGroup.tsx
+++ b/web/src/components/filter/SearchActionGroup.tsx
@@ -16,18 +16,24 @@ import {
import useKeyboardListener from "@/hooks/use-keyboard-listener";
import { toast } from "sonner";
import { Trans, useTranslation } from "react-i18next";
+import { useIsAdmin } from "@/hooks/use-is-admin";
type SearchActionGroupProps = {
selectedObjects: string[];
setSelectedObjects: (ids: string[]) => void;
pullLatestData: () => void;
+ onSelectAllObjects: () => void;
+ totalItems: number;
};
export default function SearchActionGroup({
selectedObjects,
setSelectedObjects,
pullLatestData,
+ onSelectAllObjects,
+ totalItems,
}: SearchActionGroupProps) {
const { t } = useTranslation(["components/filter"]);
+ const isAdmin = useIsAdmin();
const onClearSelected = useCallback(() => {
setSelectedObjects([]);
}, [setSelectedObjects]);
@@ -62,6 +68,7 @@ export default function SearchActionGroup({
useKeyboardListener(["Shift"], (_, modifiers) => {
setBypassDialog(modifiers.shift);
+ return false;
});
const handleDelete = useCallback(() => {
@@ -121,24 +128,37 @@ export default function SearchActionGroup({
>
{t("button.unselect", { ns: "common" })}
-
-
-
>
);
diff --git a/web/src/components/filter/SearchFilterGroup.tsx b/web/src/components/filter/SearchFilterGroup.tsx
index 1702fcc2a..fe9a70e18 100644
--- a/web/src/components/filter/SearchFilterGroup.tsx
+++ b/web/src/components/filter/SearchFilterGroup.tsx
@@ -24,9 +24,9 @@ import PlatformAwareDialog from "../overlay/dialog/PlatformAwareDialog";
import SearchFilterDialog from "../overlay/dialog/SearchFilterDialog";
import { CalendarRangeFilterButton } from "./CalendarFilterButton";
import { RadioGroup, RadioGroupItem } from "@/components/ui/radio-group";
-
import { useTranslation } from "react-i18next";
import { getTranslatedLabel } from "@/utils/i18n";
+import { useAllowedCameras } from "@/hooks/use-allowed-cameras";
type SearchFilterGroupProps = {
className: string;
@@ -46,6 +46,7 @@ export default function SearchFilterGroup({
const { data: config } = useSWR("config", {
revalidateOnFocus: false,
});
+ const allowedCameras = useAllowedCameras();
const allLabels = useMemo(() => {
if (filterList?.labels) {
@@ -57,7 +58,9 @@ export default function SearchFilterGroup({
}
const labels = new Set();
- const cameras = filter?.cameras || Object.keys(config.cameras);
+ const cameras = (filter?.cameras || allowedCameras).filter((camera) =>
+ allowedCameras.includes(camera),
+ );
cameras.forEach((camera) => {
if (camera == "birdseye") {
@@ -87,7 +90,7 @@ export default function SearchFilterGroup({
});
return [...labels].sort();
- }, [config, filterList, filter]);
+ }, [config, filterList, filter, allowedCameras]);
const allZones = useMemo(() => {
if (filterList?.zones) {
@@ -99,7 +102,9 @@ export default function SearchFilterGroup({
}
const zones = new Set();
- const cameras = filter?.cameras || Object.keys(config.cameras);
+ const cameras = (filter?.cameras || allowedCameras).filter((camera) =>
+ allowedCameras.includes(camera),
+ );
cameras.forEach((camera) => {
if (camera == "birdseye") {
@@ -118,16 +123,16 @@ export default function SearchFilterGroup({
});
return [...zones].sort();
- }, [config, filterList, filter]);
+ }, [config, filterList, filter, allowedCameras]);
const filterValues = useMemo(
() => ({
- cameras: Object.keys(config?.cameras || {}),
+ cameras: allowedCameras,
labels: Object.values(allLabels || {}),
zones: Object.values(allZones || {}),
search_type: ["thumbnail", "description"] as SearchSource[],
}),
- [config, allLabels, allZones],
+ [allLabels, allZones, allowedCameras],
);
const availableSortTypes = useMemo(() => {
@@ -246,11 +251,30 @@ function GeneralFilterButton({
updateLabelFilter,
}: GeneralFilterButtonProps) {
const { t } = useTranslation(["components/filter"]);
+ const { data: config } = useSWR("config", {
+ revalidateOnFocus: false,
+ });
const [open, setOpen] = useState(false);
const [currentLabels, setCurrentLabels] = useState(
selectedLabels,
);
+ const allAudioListenLabels = useMemo>(() => {
+ if (!config) {
+ return new Set();
+ }
+
+ const labels = new Set();
+ Object.values(config.cameras).forEach((camera) => {
+ if (camera?.audio?.enabled) {
+ camera.audio.listen.forEach((label) => {
+ labels.add(label);
+ });
+ }
+ });
+ return labels;
+ }, [config]);
+
const buttonText = useMemo(() => {
if (isMobile) {
return t("labels.all.short");
@@ -261,13 +285,17 @@ function GeneralFilterButton({
}
if (selectedLabels.length == 1) {
- return getTranslatedLabel(selectedLabels[0]);
+ const label = selectedLabels[0];
+ return getTranslatedLabel(
+ label,
+ allAudioListenLabels.has(label) ? "audio" : "object",
+ );
}
return t("labels.count", {
count: selectedLabels.length,
});
- }, [selectedLabels, t]);
+ }, [selectedLabels, allAudioListenLabels, t]);
// ui
@@ -309,11 +337,10 @@ function GeneralFilterButton({
{
if (!open) {
@@ -343,6 +370,26 @@ export function GeneralFilterContent({
onClose,
}: GeneralFilterContentProps) {
const { t } = useTranslation(["components/filter"]);
+ const { data: config } = useSWR("config", {
+ revalidateOnFocus: false,
+ });
+
+ const allAudioListenLabels = useMemo(() => {
+ if (!config) {
+ return [];
+ }
+
+ const labels = new Set();
+ Object.values(config.cameras).forEach((camera) => {
+ if (camera?.audio?.enabled) {
+ camera.audio.listen.forEach((label) => {
+ labels.add(label);
+ });
+ }
+ });
+ return [...labels].sort();
+ }, [config]);
+
return (
<>
@@ -368,7 +415,10 @@ export function GeneralFilterContent({
{allLabels.map((item) => (
{
if (isChecked) {
@@ -482,11 +532,10 @@ function SortTypeButton({
{
if (!open) {
@@ -544,9 +593,8 @@ export function SortTypeContent({
className="w-full space-y-1"
>
{availableSortTypes.map((value) => (
-
+
+ {steps.map((_, idx) => (
+ idx
+ ? "bg-muted-foreground"
+ : "bg-muted",
+ )}
+ />
+ ))}
+
+ );
+ }
+
+ // Default variant (original behavior)
return (
-
+
{steps.map((name, idx) => (
(null);
+ const dropzoneRef = useRef(null);
+
+ // Auto focus the dropzone
+ useEffect(() => {
+ if (dropzoneRef.current && !preview) {
+ dropzoneRef.current.focus();
+ }
+ }, [preview]);
+
+ // Clean up preview URL on unmount or preview change
+ useEffect(() => {
+ return () => {
+ if (preview) {
+ URL.revokeObjectURL(preview);
+ }
+ };
+ }, [preview]);
const formSchema = z.object({
file: z
@@ -52,9 +69,6 @@ export default function ImageEntry({
// Create preview
const objectUrl = URL.createObjectURL(file);
setPreview(objectUrl);
-
- // Clean up preview URL when component unmounts
- return () => URL.revokeObjectURL(objectUrl);
}
},
[form],
@@ -68,6 +82,31 @@ export default function ImageEntry({
multiple: false,
});
+ const handlePaste = useCallback(
+ (event: React.ClipboardEvent) => {
+ event.preventDefault();
+ const clipboardItems = Array.from(event.clipboardData.items);
+ for (const item of clipboardItems) {
+ if (item.type.startsWith("image/")) {
+ const blob = item.getAsFile();
+ if (blob && blob.size <= maxSize) {
+ const mimeType = blob.type.split("/")[1];
+ const extension = `.${mimeType}`;
+ if (accept["image/*"].includes(extension)) {
+ const fileName = blob.name || `pasted-image.${mimeType}`;
+ const file = new File([blob], fileName, { type: blob.type });
+ form.setValue("file", file, { shouldValidate: true });
+ const objectUrl = URL.createObjectURL(file);
+ setPreview(objectUrl);
+ return; // Take the first valid image
+ }
+ }
+ }
+ }
+ },
+ [form, maxSize, accept],
+ );
+
const onSubmit = useCallback(
(data: z.infer) => {
if (!data.file) return;
@@ -90,7 +129,12 @@ export default function ImageEntry({
render={() => (
-
+
{!preview ? (
>(() => {
+ if (!config) {
+ return new Set();
+ }
+
+ const labels = new Set();
+ Object.values(config.cameras).forEach((camera) => {
+ if (camera?.audio?.enabled) {
+ camera.audio.listen.forEach((label) => {
+ labels.add(label);
+ });
+ }
+ });
+ return labels;
+ }, [config]);
+
+ const translatedAudioLabelMap = useMemo