mirror of
https://github.com/bitwarden/browser
synced 2025-12-20 02:03:39 +00:00
Merge branch 'main' of github.com:bitwarden/clients
This commit is contained in:
1
.browserslistrc
Normal file
1
.browserslistrc
Normal file
@@ -0,0 +1 @@
|
|||||||
|
> 0.5%, last 3 major versions, Firefox ESR, not dead
|
||||||
2
.github/workflows/build-cli.yml
vendored
2
.github/workflows/build-cli.yml
vendored
@@ -65,7 +65,7 @@ jobs:
|
|||||||
os:
|
os:
|
||||||
[
|
[
|
||||||
{ base: "linux", distro: "ubuntu-22.04" },
|
{ base: "linux", distro: "ubuntu-22.04" },
|
||||||
{ base: "mac", distro: "macos-11" }
|
{ base: "mac", distro: "macos-13" }
|
||||||
]
|
]
|
||||||
license_type:
|
license_type:
|
||||||
[
|
[
|
||||||
|
|||||||
28
.github/workflows/build-desktop.yml
vendored
28
.github/workflows/build-desktop.yml
vendored
@@ -444,10 +444,7 @@ jobs:
|
|||||||
|
|
||||||
macos-build:
|
macos-build:
|
||||||
name: MacOS Build
|
name: MacOS Build
|
||||||
# Note, this workflow is running on macOS 11 to maintain compatibility with macOS 10.15 Catalina,
|
runs-on: macos-13
|
||||||
# as the newer versions will case the native modules to be incompatible with older macOS systems
|
|
||||||
# This version should stay pinned until we drop support for macOS 10.15, or we drop the native modules
|
|
||||||
runs-on: macos-11
|
|
||||||
needs: setup
|
needs: setup
|
||||||
env:
|
env:
|
||||||
_PACKAGE_VERSION: ${{ needs.setup.outputs.package_version }}
|
_PACKAGE_VERSION: ${{ needs.setup.outputs.package_version }}
|
||||||
@@ -605,10 +602,7 @@ jobs:
|
|||||||
|
|
||||||
macos-package-github:
|
macos-package-github:
|
||||||
name: MacOS Package GitHub Release Assets
|
name: MacOS Package GitHub Release Assets
|
||||||
# Note, this workflow is running on macOS 11 to maintain compatibility with macOS 10.15 Catalina,
|
runs-on: macos-13
|
||||||
# as the newer versions will case the native modules to be incompatible with older macOS systems
|
|
||||||
# This version should stay pinned until we drop support for macOS 10.15, or we drop the native modules
|
|
||||||
runs-on: macos-11
|
|
||||||
needs:
|
needs:
|
||||||
- browser-build
|
- browser-build
|
||||||
- macos-build
|
- macos-build
|
||||||
@@ -814,10 +808,7 @@ jobs:
|
|||||||
|
|
||||||
macos-package-mas:
|
macos-package-mas:
|
||||||
name: MacOS Package Prod Release Asset
|
name: MacOS Package Prod Release Asset
|
||||||
# Note, this workflow is running on macOS 11 to maintain compatibility with macOS 10.15 Catalina,
|
runs-on: macos-13
|
||||||
# as the newer versions will case the native modules to be incompatible with older macOS systems
|
|
||||||
# This version should stay pinned until we drop support for macOS 10.15, or we drop the native modules
|
|
||||||
runs-on: macos-11
|
|
||||||
needs:
|
needs:
|
||||||
- browser-build
|
- browser-build
|
||||||
- macos-build
|
- macos-build
|
||||||
@@ -1014,11 +1005,7 @@ jobs:
|
|||||||
|
|
||||||
macos-package-dev:
|
macos-package-dev:
|
||||||
name: MacOS Package Dev Release Asset
|
name: MacOS Package Dev Release Asset
|
||||||
if: false # We need to look into how code signing works for dev
|
runs-on: macos-13
|
||||||
# Note, this workflow is running on macOS 11 to maintain compatibility with macOS 10.15 Catalina,
|
|
||||||
# as the newer versions will case the native modules to be incompatible with older macOS systems
|
|
||||||
# This version should stay pinned until we drop support for macOS 10.15, or we drop the native modules
|
|
||||||
runs-on: macos-11
|
|
||||||
needs:
|
needs:
|
||||||
- browser-build
|
- browser-build
|
||||||
- macos-build
|
- macos-build
|
||||||
@@ -1188,14 +1175,15 @@ jobs:
|
|||||||
APPLE_ID_PASSWORD: ${{ secrets.APPLE_ID_PASSWORD }}
|
APPLE_ID_PASSWORD: ${{ secrets.APPLE_ID_PASSWORD }}
|
||||||
|
|
||||||
- name: Zip masdev asset
|
- name: Zip masdev asset
|
||||||
working-directory: ./dist/mas-dev-universal
|
run: |
|
||||||
run: zip -r Bitwarden-${{ env.PACKAGE_VERSION }}-masdev-universal.zip Bitwarden.app
|
cd dist/mas-dev-universal
|
||||||
|
zip -r Bitwarden-${{ env._PACKAGE_VERSION }}-masdev-universal.zip Bitwarden.app
|
||||||
|
|
||||||
- name: Upload masdev artifact
|
- name: Upload masdev artifact
|
||||||
uses: actions/upload-artifact@5d5d22a31266ced268874388b861e4b58bb5c2f3 # v4.3.1
|
uses: actions/upload-artifact@5d5d22a31266ced268874388b861e4b58bb5c2f3 # v4.3.1
|
||||||
with:
|
with:
|
||||||
name: Bitwarden-${{ env._PACKAGE_VERSION }}-masdev-universal.zip
|
name: Bitwarden-${{ env._PACKAGE_VERSION }}-masdev-universal.zip
|
||||||
path: apps/desktop/dist/mas-universal/Bitwarden-${{ env._PACKAGE_VERSION }}-masdev-universal.zip
|
path: apps/desktop/dist/mas-dev-universal/Bitwarden-${{ env._PACKAGE_VERSION }}-masdev-universal.zip
|
||||||
if-no-files-found: error
|
if-no-files-found: error
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
27
.github/workflows/release-desktop-beta.yml
vendored
27
.github/workflows/release-desktop-beta.yml
vendored
@@ -393,10 +393,7 @@ jobs:
|
|||||||
|
|
||||||
macos-build:
|
macos-build:
|
||||||
name: MacOS Build
|
name: MacOS Build
|
||||||
# Note, this workflow is running on macOS 11 to maintain compatibility with macOS 10.15 Catalina,
|
runs-on: macos-13
|
||||||
# as the newer versions will case the native modules to be incompatible with older macOS systems
|
|
||||||
# This version should stay pinned until we drop support for macOS 10.15, or we drop the native modules
|
|
||||||
runs-on: macos-11
|
|
||||||
needs: setup
|
needs: setup
|
||||||
env:
|
env:
|
||||||
_PACKAGE_VERSION: ${{ needs.setup.outputs.release-version }}
|
_PACKAGE_VERSION: ${{ needs.setup.outputs.release-version }}
|
||||||
@@ -525,10 +522,7 @@ jobs:
|
|||||||
|
|
||||||
macos-package-github:
|
macos-package-github:
|
||||||
name: MacOS Package GitHub Release Assets
|
name: MacOS Package GitHub Release Assets
|
||||||
# Note, this workflow is running on macOS 11 to maintain compatibility with macOS 10.15 Catalina,
|
runs-on: macos-13
|
||||||
# as the newer versions will case the native modules to be incompatible with older macOS systems
|
|
||||||
# This version should stay pinned until we drop support for macOS 10.15, or we drop the native modules
|
|
||||||
runs-on: macos-11
|
|
||||||
needs:
|
needs:
|
||||||
- setup
|
- setup
|
||||||
- macos-build
|
- macos-build
|
||||||
@@ -665,7 +659,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Download artifact from hotfix-rc
|
- name: Download artifact from hotfix-rc
|
||||||
if: github.ref == 'refs/heads/hotfix-rc'
|
if: github.ref == 'refs/heads/hotfix-rc'
|
||||||
uses: dawidd6/action-download-artifact@71072fbb1229e1317f1a8de6b04206afb461bd67 # v3.1.2
|
uses: bitwarden/gh-actions/download-artifacts@main
|
||||||
with:
|
with:
|
||||||
workflow: build-browser.yml
|
workflow: build-browser.yml
|
||||||
workflow_conclusion: success
|
workflow_conclusion: success
|
||||||
@@ -674,7 +668,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Download artifact from rc
|
- name: Download artifact from rc
|
||||||
if: github.ref == 'refs/heads/rc'
|
if: github.ref == 'refs/heads/rc'
|
||||||
uses: dawidd6/action-download-artifact@71072fbb1229e1317f1a8de6b04206afb461bd67 # v3.1.2
|
uses: bitwarden/gh-actions/download-artifacts@main
|
||||||
with:
|
with:
|
||||||
workflow: build-browser.yml
|
workflow: build-browser.yml
|
||||||
workflow_conclusion: success
|
workflow_conclusion: success
|
||||||
@@ -683,7 +677,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Download artifacts from main
|
- name: Download artifacts from main
|
||||||
if: ${{ github.ref != 'refs/heads/rc' && github.ref != 'refs/heads/hotfix-rc' }}
|
if: ${{ github.ref != 'refs/heads/rc' && github.ref != 'refs/heads/hotfix-rc' }}
|
||||||
uses: dawidd6/action-download-artifact@71072fbb1229e1317f1a8de6b04206afb461bd67 # v3.1.2
|
uses: bitwarden/gh-actions/download-artifacts@main
|
||||||
with:
|
with:
|
||||||
workflow: build-browser.yml
|
workflow: build-browser.yml
|
||||||
workflow_conclusion: success
|
workflow_conclusion: success
|
||||||
@@ -738,10 +732,7 @@ jobs:
|
|||||||
|
|
||||||
macos-package-mas:
|
macos-package-mas:
|
||||||
name: MacOS Package Prod Release Asset
|
name: MacOS Package Prod Release Asset
|
||||||
# Note, this workflow is running on macOS 11 to maintain compatibility with macOS 10.15 Catalina,
|
runs-on: macos-13
|
||||||
# as the newer versions will case the native modules to be incompatible with older macOS systems
|
|
||||||
# This version should stay pinned until we drop support for macOS 10.15, or we drop the native modules
|
|
||||||
runs-on: macos-11
|
|
||||||
needs:
|
needs:
|
||||||
- setup
|
- setup
|
||||||
- macos-build
|
- macos-build
|
||||||
@@ -873,7 +864,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Download artifact from hotfix-rc
|
- name: Download artifact from hotfix-rc
|
||||||
if: github.ref == 'refs/heads/hotfix-rc'
|
if: github.ref == 'refs/heads/hotfix-rc'
|
||||||
uses: dawidd6/action-download-artifact@71072fbb1229e1317f1a8de6b04206afb461bd67 # v3.1.2
|
uses: bitwarden/gh-actions/download-artifacts@main
|
||||||
with:
|
with:
|
||||||
workflow: build-browser.yml
|
workflow: build-browser.yml
|
||||||
workflow_conclusion: success
|
workflow_conclusion: success
|
||||||
@@ -882,7 +873,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Download artifact from rc
|
- name: Download artifact from rc
|
||||||
if: github.ref == 'refs/heads/rc'
|
if: github.ref == 'refs/heads/rc'
|
||||||
uses: dawidd6/action-download-artifact@71072fbb1229e1317f1a8de6b04206afb461bd67 # v3.1.2
|
uses: bitwarden/gh-actions/download-artifacts@main
|
||||||
with:
|
with:
|
||||||
workflow: build-browser.yml
|
workflow: build-browser.yml
|
||||||
workflow_conclusion: success
|
workflow_conclusion: success
|
||||||
@@ -891,7 +882,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Download artifact from main
|
- name: Download artifact from main
|
||||||
if: ${{ github.ref != 'refs/heads/rc' && github.ref != 'refs/heads/hotfix-rc' }}
|
if: ${{ github.ref != 'refs/heads/rc' && github.ref != 'refs/heads/hotfix-rc' }}
|
||||||
uses: dawidd6/action-download-artifact@71072fbb1229e1317f1a8de6b04206afb461bd67 # v3.1.2
|
uses: bitwarden/gh-actions/download-artifacts@main
|
||||||
with:
|
with:
|
||||||
workflow: build-browser.yml
|
workflow: build-browser.yml
|
||||||
workflow_conclusion: success
|
workflow_conclusion: success
|
||||||
|
|||||||
6
.github/workflows/test.yml
vendored
6
.github/workflows/test.yml
vendored
@@ -48,10 +48,12 @@ jobs:
|
|||||||
# Tests in apps/ are typechecked when their app is built, so we just do it here for libs/
|
# Tests in apps/ are typechecked when their app is built, so we just do it here for libs/
|
||||||
# See https://bitwarden.atlassian.net/browse/EC-497
|
# See https://bitwarden.atlassian.net/browse/EC-497
|
||||||
- name: Run typechecking
|
- name: Run typechecking
|
||||||
run: npm run test:types --coverage
|
run: npm run test:types
|
||||||
|
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: npm run test --coverage
|
# maxWorkers is a workaround for a memory leak that crashes tests in CI:
|
||||||
|
# https://github.com/facebook/jest/issues/9430#issuecomment-1149882002
|
||||||
|
run: npm test -- --coverage --maxWorkers=3
|
||||||
|
|
||||||
- name: Report test results
|
- name: Report test results
|
||||||
uses: dorny/test-reporter@eaa763f6ffc21c7a37837f56cd5f9737f27fc6c8 # v1.8.0
|
uses: dorny/test-reporter@eaa763f6ffc21c7a37837f56cd5f9737f27fc6c8 # v1.8.0
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@bitwarden/browser",
|
"name": "@bitwarden/browser",
|
||||||
"version": "2024.5.1",
|
"version": "2024.6.0",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "cross-env MANIFEST_VERSION=3 webpack",
|
"build": "cross-env MANIFEST_VERSION=3 webpack",
|
||||||
"build:mv2": "webpack",
|
"build:mv2": "webpack",
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "إلغاء القفل"
|
"message": "إلغاء القفل"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "إظهار خيارات قائمة السياق"
|
"message": "إظهار خيارات قائمة السياق"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "داكن مُشمس",
|
"message": "داكن مُشمس",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "تصدير الخزنة"
|
"message": "تصدير الخزنة"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "صيغة الملف"
|
"message": "صيغة الملف"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "تحذير",
|
"message": "تحذير",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "خطأ"
|
"message": "خطأ"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Kilidi aç"
|
"message": "Kilidi aç"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Əlavə seçimlər"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Konteks menyu seçimlərini göstər"
|
"message": "Konteks menyu seçimlərini göstər"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Günəşli tünd",
|
"message": "Günəşli tünd",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Buradan xaricə köçür"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Anbarı xaricə köçür"
|
"message": "Anbarı xaricə köçür"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Fayl formatı"
|
"message": "Fayl formatı"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Bu faylın xaricə köçürülməsi, parolla qorunacaq və şifrəsini açmaq üçün fayl parolu tələb olunacaq."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Fayl parolu"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Bu parol, bu faylı daxilə və xaricə köçürmək üçün istifadə olunacaq"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Xaricə köçürməni şifrələmək və daxilə köçürməni yalnız mövcud Bitwarden hesabı ilə məhdudlaşdırmaq üçün hesabınızın istifadəçi adı və Ana Parolundan əldə edilən hesab şifrələmə açarınızı istifadə edin."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Xaricə köçürməni şifrələmək üçün bir fayl parolu təyin edin və şifrəni açma parolunu istifadə edərək bunu istənilən Bitwarden hesabına köçürün."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Xaricə köçürmə növü"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Hesab məhdudlaşdırıldı"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Fayl parolu\" və \"Fayl parolunu təsdiqlə\" uyuşmur."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "XƏBƏRDARLIQ",
|
"message": "XƏBƏRDARLIQ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Təşkilat anbarını xaricə köçürmə"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Yalnız $ORGANIZATION$ ilə əlaqələndirilmiş təşkilat anbarı ixrac ediləcək. Fərdi anbardakı və digər təşkilat elementlər daxil edilmir.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Xəta"
|
"message": "Xəta"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Разблакіраваць"
|
"message": "Разблакіраваць"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Паказваць параметры кантэкстнага меню"
|
"message": "Паказваць параметры кантэкстнага меню"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Экспартаваць сховішча"
|
"message": "Экспартаваць сховішча"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Фармат файла"
|
"message": "Фармат файла"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ПАПЯРЭДЖАННЕ",
|
"message": "ПАПЯРЭДЖАННЕ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Памылка"
|
"message": "Памылка"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Отключване"
|
"message": "Отключване"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Допълнителни настройки"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Показване на опции в контекстното меню"
|
"message": "Показване на опции в контекстното меню"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Преекспонирано тъмен",
|
"message": "Преекспонирано тъмен",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Изнасяне от"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Изнасяне на трезора"
|
"message": "Изнасяне на трезора"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Формат на файла"
|
"message": "Формат на файла"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Изнесеният файл ще бъде защитен с парола, която ще бъде необходима за дешифриране на файла."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Парола на файла"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Парола ще се използва при изнасянето и при внасянето на този файл"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Използвайте ключа си за шифриране, който се получава чрез комбиниране на потребителското име на регистрацията Ви и главната парола. С него изнасянето ще се шифрира и внасянето ще бъда възможно само в текущата регистрация в Битуорден."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Задайте парола за файла, за да шифровате изнесените данни. Ще можете да внесете данните във всяка регистрация в Битуорден използвайки паролата за дешифриране."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Вид изнасяне"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Регистрацията е ограничена"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "Дънните в полетата „Парола на файла“ и „Потвърждаване на паролата на файла“ не съвпадат."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ВНИМАНИЕ",
|
"message": "ВНИМАНИЕ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Изнасяне на трезора на организацията"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Ще бъдат изнесени само записите от трезора свързан с $ORGANIZATION$. Записите в отделните лични трезори и тези в други организации няма да бъдат включени.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Грешка"
|
"message": "Грешка"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "ভল্ট রফতানি"
|
"message": "ভল্ট রফতানি"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "ফাইলের ধরণ"
|
"message": "ফাইলের ধরণ"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "সতর্কতা",
|
"message": "সতর্কতা",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Desbloqueja"
|
"message": "Desbloqueja"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Mostra les opcions del menú contextual"
|
"message": "Mostra les opcions del menú contextual"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solaritzat fosc",
|
"message": "Solaritzat fosc",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Exporta caixa forta"
|
"message": "Exporta caixa forta"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Format de fitxer"
|
"message": "Format de fitxer"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ADVERTIMENT",
|
"message": "ADVERTIMENT",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Odemknout"
|
"message": "Odemknout"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Další volby"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Zobrazit volby v kontextovém menu"
|
"message": "Zobrazit volby v kontextovém menu"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Tmavý (solarizovaný)",
|
"message": "Tmavý (solarizovaný)",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Exportovat z"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Exportovat trezor"
|
"message": "Exportovat trezor"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Formát souboru"
|
"message": "Formát souboru"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Tento soubor exportu bude chráněn heslem a k dešifrování bude vyžadovat heslo souboru."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Heslo souboru"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Toto heslo bude použito pro export a import tohoto souboru"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Pro zašifrování exportu a omezení importu pouze na aktuální účet Bitwardenu použijte šifrovací klíč Vašeho účtu odvozený z uživatelského jména a hlavního hesla."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Nastavte heslo pro šifrování exportu a importujte ho do libovolného účtu Bitwardenu pomocí hesla pro dešifrování."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Typ exportu"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Účet je omezený"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Heslo souboru\" a \"Potvrzení hesla souboru\" se neshodují."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "VAROVÁNÍ",
|
"message": "VAROVÁNÍ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exportování trezoru organizace"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Exportován bude jen trezor organizace přidružený k položce $ORGANIZATION$. Osobní položky trezoru a položky z jiných organizací nebudou zahrnuty.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Chyba"
|
"message": "Chyba"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Datgloi"
|
"message": "Datgloi"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Allforio'r gell"
|
"message": "Allforio'r gell"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Fformat y ffeil"
|
"message": "Fformat y ffeil"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "RHYBUDD",
|
"message": "RHYBUDD",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Gwall"
|
"message": "Gwall"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Oplås"
|
"message": "Oplås"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Yderligere indstillinger"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Vis indstillinger i kontekstmenuen"
|
"message": "Vis indstillinger i kontekstmenuen"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solariseret mørk",
|
"message": "Solariseret mørk",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Eksportér fra"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Eksportér boks"
|
"message": "Eksportér boks"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Filformat"
|
"message": "Filformat"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Denne fileksport vil være adgangskodebeskyttet og kræve filadgangskoden at dekryptere."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Filadgangskode"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Denne adgangskode vil blive brugt ved eksport og import af denne fil"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Brug kontokrypteringsnøglen, dannet af kontobrugernavn og Hovedadgangskode, for at kryptere eksporten og hindre import til andre end den aktuelle Bitwarden-konto."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Opsæt en adgangskode til både at kryptere eksporten samt dekryptere denne ved import til enhver Bitwarden-konto."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Eksporttype"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Konto begrænset"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“Filadgangskode” og “Bekræft filadgangskode“ matcher ikke."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ADVARSEL",
|
"message": "ADVARSEL",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Eksport af organisationsboks"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Kun organisationsboksen tilknyttet $ORGANIZATION$ eksporteres. Emner i individuelle bokse eller andre organisationer medtages ikke.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Fejl"
|
"message": "Fejl"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Entsperren"
|
"message": "Entsperren"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Weitere Optionen"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Kontextmenüoptionen anzeigen"
|
"message": "Kontextmenüoptionen anzeigen"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export aus"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Tresor exportieren"
|
"message": "Tresor exportieren"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Dateiformat"
|
"message": "Dateiformat"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Dieser Datei-Export ist passwortgeschützt und erfordert das Dateipasswort zum Entschlüsseln."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Dateipasswort"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Dieses Passwort wird zum Exportieren und Importieren dieser Datei verwendet"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Verwende den Verschlüsselungsschlüssel deines Kontos, abgeleitet vom Benutzernamen und Master-Passwort, um den Export zu verschlüsseln und den Import auf das aktuelle Bitwarden-Konto zu beschränken."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Lege ein Dateipasswort fest, um den Export zu verschlüsseln und importiere ihn in ein beliebiges Bitwarden-Konto, wobei das Passwort zum Entschlüsseln genutzt wird."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Exporttyp"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Konto eingeschränkt"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "„Dateipasswort“ und „Dateipasswort bestätigen“ stimmen nicht überein."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ACHTUNG",
|
"message": "ACHTUNG",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Tresor der Organisation wird exportiert"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Nur der mit $ORGANIZATION$ verbundene Organisationstresor wird exportiert. Einträge in persönlichen Tresoren oder anderen Organisationen werden nicht berücksichtigt.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Fehler"
|
"message": "Fehler"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Ξεκλείδωμα"
|
"message": "Ξεκλείδωμα"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Εμφάνιση επιλογών μενού περιβάλλοντος"
|
"message": "Εμφάνιση επιλογών μενού περιβάλλοντος"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Σκούρο",
|
"message": "Solarized Σκούρο",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Εξαγωγή Vault"
|
"message": "Εξαγωγή Vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Μορφή αρχείου"
|
"message": "Μορφή αρχείου"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ΠΡΟΕΙΔΟΠΟΙΗΣΗ",
|
"message": "ΠΡΟΕΙΔΟΠΟΙΗΣΗ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Σφάλμα"
|
"message": "Σφάλμα"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -389,6 +389,9 @@
|
|||||||
"favorite": {
|
"favorite": {
|
||||||
"message": "Favorite"
|
"message": "Favorite"
|
||||||
},
|
},
|
||||||
|
"unfavorite": {
|
||||||
|
"message": "Unfavorite"
|
||||||
|
},
|
||||||
"notes": {
|
"notes": {
|
||||||
"message": "Notes"
|
"message": "Notes"
|
||||||
},
|
},
|
||||||
@@ -410,6 +413,9 @@
|
|||||||
"launch": {
|
"launch": {
|
||||||
"message": "Launch"
|
"message": "Launch"
|
||||||
},
|
},
|
||||||
|
"launchWebsite": {
|
||||||
|
"message": "Launch website"
|
||||||
|
},
|
||||||
"website": {
|
"website": {
|
||||||
"message": "Website"
|
"message": "Website"
|
||||||
},
|
},
|
||||||
@@ -599,6 +605,9 @@
|
|||||||
"loggedOut": {
|
"loggedOut": {
|
||||||
"message": "Logged out"
|
"message": "Logged out"
|
||||||
},
|
},
|
||||||
|
"loggedOutDesc": {
|
||||||
|
"message": "You have been logged out of your account."
|
||||||
|
},
|
||||||
"loginExpired": {
|
"loginExpired": {
|
||||||
"message": "Your login session has expired."
|
"message": "Your login session has expired."
|
||||||
},
|
},
|
||||||
@@ -1107,6 +1116,15 @@
|
|||||||
"selfHostedEnvironmentFooter": {
|
"selfHostedEnvironmentFooter": {
|
||||||
"message": "Specify the base URL of your on-premises hosted Bitwarden installation."
|
"message": "Specify the base URL of your on-premises hosted Bitwarden installation."
|
||||||
},
|
},
|
||||||
|
"selfHostedBaseUrlHint": {
|
||||||
|
"message": "Specify the base URL of your on-premises hosted Bitwarden installation. Example: https://bitwarden.company.com"
|
||||||
|
},
|
||||||
|
"selfHostedCustomEnvHeader" :{
|
||||||
|
"message": "For advanced configuration, you can specify the base URL of each service independently."
|
||||||
|
},
|
||||||
|
"selfHostedEnvFormInvalid" :{
|
||||||
|
"message": "You must add either the base Server URL or at least one custom environment."
|
||||||
|
},
|
||||||
"customEnvironment": {
|
"customEnvironment": {
|
||||||
"message": "Custom environment"
|
"message": "Custom environment"
|
||||||
},
|
},
|
||||||
@@ -1419,6 +1437,15 @@
|
|||||||
"collections": {
|
"collections": {
|
||||||
"message": "Collections"
|
"message": "Collections"
|
||||||
},
|
},
|
||||||
|
"nCollections": {
|
||||||
|
"message": "$COUNT$ collections",
|
||||||
|
"placeholders": {
|
||||||
|
"count": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"favorites": {
|
"favorites": {
|
||||||
"message": "Favorites"
|
"message": "Favorites"
|
||||||
},
|
},
|
||||||
@@ -1648,6 +1675,9 @@
|
|||||||
"autoFillAndSave": {
|
"autoFillAndSave": {
|
||||||
"message": "Auto-fill and save"
|
"message": "Auto-fill and save"
|
||||||
},
|
},
|
||||||
|
"fillAndSave": {
|
||||||
|
"message": "Fill and save"
|
||||||
|
},
|
||||||
"autoFillSuccessAndSavedUri": {
|
"autoFillSuccessAndSavedUri": {
|
||||||
"message": "Item auto-filled and URI saved"
|
"message": "Item auto-filled and URI saved"
|
||||||
},
|
},
|
||||||
@@ -1744,6 +1774,12 @@
|
|||||||
"ok": {
|
"ok": {
|
||||||
"message": "Ok"
|
"message": "Ok"
|
||||||
},
|
},
|
||||||
|
"errorRefreshingAccessToken":{
|
||||||
|
"message": "Access Token Refresh Error"
|
||||||
|
},
|
||||||
|
"errorRefreshingAccessTokenDesc":{
|
||||||
|
"message": "No refresh token or API keys found. Please try logging out and logging back in."
|
||||||
|
},
|
||||||
"desktopSyncVerificationTitle": {
|
"desktopSyncVerificationTitle": {
|
||||||
"message": "Desktop sync verification"
|
"message": "Desktop sync verification"
|
||||||
},
|
},
|
||||||
@@ -3263,7 +3299,7 @@
|
|||||||
"clearFiltersOrTryAnother": {
|
"clearFiltersOrTryAnother": {
|
||||||
"message": "Clear filters or try another search term"
|
"message": "Clear filters or try another search term"
|
||||||
},
|
},
|
||||||
"copyInfo": {
|
"copyInfoLabel": {
|
||||||
"message": "Copy info, $ITEMNAME$",
|
"message": "Copy info, $ITEMNAME$",
|
||||||
"description": "Aria label for a button that opens a menu with options to copy information from an item.",
|
"description": "Aria label for a button that opens a menu with options to copy information from an item.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
@@ -3273,7 +3309,37 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"moreOptions": {
|
"copyInfoTitle": {
|
||||||
|
"message": "Copy info - $ITEMNAME$",
|
||||||
|
"description": "Title for a button that opens a menu with options to copy information from an item.",
|
||||||
|
"placeholders": {
|
||||||
|
"itemname": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "Secret Item"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"copyNoteLabel": {
|
||||||
|
"message": "Copy Note, $ITEMNAME$",
|
||||||
|
"description": "Aria label for a button copies a note to the clipboard.",
|
||||||
|
"placeholders": {
|
||||||
|
"itemname": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "Secret Note Item"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"copyNoteTitle": {
|
||||||
|
"message": "Copy Note - $ITEMNAME$",
|
||||||
|
"description": "Title for a button copies a note to the clipboard.",
|
||||||
|
"placeholders": {
|
||||||
|
"itemname": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "Secret Note Item"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"moreOptionsLabel": {
|
||||||
"message": "More options, $ITEMNAME$",
|
"message": "More options, $ITEMNAME$",
|
||||||
"description": "Aria label for a button that opens a menu with more options for an item.",
|
"description": "Aria label for a button that opens a menu with more options for an item.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
@@ -3283,6 +3349,38 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"moreOptionsTitle": {
|
||||||
|
"message": "More options - $ITEMNAME$",
|
||||||
|
"description": "Title for a button that opens a menu with more options for an item.",
|
||||||
|
"placeholders": {
|
||||||
|
"itemname": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "Secret Item"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"viewItemTitle": {
|
||||||
|
"message": "View item - $ITEMNAME$",
|
||||||
|
"description": "Title for a link that opens a view for an item.",
|
||||||
|
"placeholders": {
|
||||||
|
"itemname": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "Secret Item"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"assignCollections": {
|
||||||
|
"message": "Assign collections"
|
||||||
|
},
|
||||||
|
"copyEmail": {
|
||||||
|
"message": "Copy email"
|
||||||
|
},
|
||||||
|
"copyPhone": {
|
||||||
|
"message": "Copy phone"
|
||||||
|
},
|
||||||
|
"copyAddress": {
|
||||||
|
"message": "Copy address"
|
||||||
|
},
|
||||||
"adminConsole": {
|
"adminConsole": {
|
||||||
"message": "Admin Console"
|
"message": "Admin Console"
|
||||||
},
|
},
|
||||||
@@ -3333,5 +3431,14 @@
|
|||||||
"example": "Work"
|
"example": "Work"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"itemsWithNoFolder": {
|
||||||
|
"message": "Items with no folder"
|
||||||
|
},
|
||||||
|
"organizationIsDeactivated": {
|
||||||
|
"message": "Organization is deactivated"
|
||||||
|
},
|
||||||
|
"contactYourOrgAdmin": {
|
||||||
|
"message": "Items in deactivated organizations cannot be accessed. Contact your organization owner for assistance."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organisation vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organisation vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organisations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarised Dark",
|
"message": "Solarised Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organisation vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organisation vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organisations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Desbloquear"
|
"message": "Desbloquear"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Mostrar las opciones de menú contextuales"
|
"message": "Mostrar las opciones de menú contextuales"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Exportar desde"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Exportar caja fuerte"
|
"message": "Exportar caja fuerte"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Formato de archivo"
|
"message": "Formato de archivo"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Esta exportación de archivo estará protegida por contraseña y requerirá la contraseña del archivo para descifrarla."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Contraseña del archivo"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Esta contraseña se utilizará para exportar e importar este archivo"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Utiliza la clave de cifrado de tu cuenta, derivada del nombre de usuario y la contraseña maestra de tu cuenta, para cifrar la exportación y restringir la importación solo a la cuenta actual de Bitwarden."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Establece una contraseña de archivo para cifrar la exportación e importarlo a cualquier cuenta de Bitwarden utilizando la contraseña para el descifrado."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Tipo de exportación"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Cuenta restringida"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Contraseña de archivo\" y \"Confirmar contraseña de archivo\" no coinciden."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ADVERTENCIA",
|
"message": "ADVERTENCIA",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exportando caja fuerte de la organización"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Solo se exportará la caja fuerte de la organización asociada a $ORGANIZATION$. Los elementos en las cajas fuertes individuales o de otras organizaciones no serán incluidos.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Lukusta lahti"
|
"message": "Lukusta lahti"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Kuva parema kliki menüü valikud"
|
"message": "Kuva parema kliki menüü valikud"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized tume",
|
"message": "Solarized tume",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Ekspordi hoidla"
|
"message": "Ekspordi hoidla"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Failivorming"
|
"message": "Failivorming"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "HOIATUS",
|
"message": "HOIATUS",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Viga"
|
"message": "Viga"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Erakutsi laster-menuko aukerak"
|
"message": "Erakutsi laster-menuko aukerak"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized iluna",
|
"message": "Solarized iluna",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Esportatu kutxa gotorra"
|
"message": "Esportatu kutxa gotorra"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Fitxategiaren formatua"
|
"message": "Fitxategiaren formatua"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "KONTUZ",
|
"message": "KONTUZ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Akatsa"
|
"message": "Akatsa"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "باز کردن قفل"
|
"message": "باز کردن قفل"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "نمایش گزینههای منوی زمینه"
|
"message": "نمایش گزینههای منوی زمینه"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "تاریک خورشیدی",
|
"message": "تاریک خورشیدی",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "برون ریزی گاوصندوق"
|
"message": "برون ریزی گاوصندوق"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "فرمت پرونده"
|
"message": "فرمت پرونده"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "اخطار",
|
"message": "اخطار",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "خطا"
|
"message": "خطا"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Avaa"
|
"message": "Avaa"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Lisäasetukset"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Näytä sisältövalikon valinnat"
|
"message": "Näytä sisältövalikon valinnat"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized, tumma",
|
"message": "Solarized, tumma",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Vie lähteestä"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Vie holvi"
|
"message": "Vie holvi"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Tiedostomuoto"
|
"message": "Tiedostomuoto"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Tämä vientitiedosto suojataan salasanalla, joka on syötettävä ja salauksen purkamiseksi."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Tiedoston salasana"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Tätä salasanaa käytetään tämän tiedoston viennissä ja tuonnissa"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Salaa vienti ja rajoita tuonti vain nykyiselle Bitwarden-tilille tilisi käyttäjätunnukseen ja pääsalasanaan pohjautuvalla salausavaimella."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Salaa vientitiedosto salasanalla, joka mahdollistaa sen tuonnin mille tahansa Bitwarden-tilille."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Viennin tyyppi"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Rajoitettu tilille"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Tiedoston salasana\" ja \"Vahvista tiedoston salasana\" eivät täsmää."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "VAROITUS",
|
"message": "VAROITUS",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Organisaation holvin vienti"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Vain organisaatioon $ORGANIZATION$ liitetyn holvin kohteet viedään. Yksityisen holvin ja muiden organisaatioiden kohteita ei sisällytetä.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Virhe"
|
"message": "Virhe"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "I-unlock"
|
"message": "I-unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Ipakita ang mga opsyon ng menu ng konteksto"
|
"message": "Ipakita ang mga opsyon ng menu ng konteksto"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "I-export vault"
|
"message": "I-export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Format ng file"
|
"message": "Format ng file"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "BABALA",
|
"message": "BABALA",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Mali"
|
"message": "Mali"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Déverrouiller"
|
"message": "Déverrouiller"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Afficher les options du menu contextuel"
|
"message": "Afficher les options du menu contextuel"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Exporter le coffre"
|
"message": "Exporter le coffre"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Format de fichier"
|
"message": "Format de fichier"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "AVERTISSEMENT",
|
"message": "AVERTISSEMENT",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Erreur"
|
"message": "Erreur"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Desbloquear"
|
"message": "Desbloquear"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarizado escuro",
|
"message": "Solarizado escuro",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Exportar caixa forte"
|
"message": "Exportar caixa forte"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Formato de ficheiro"
|
"message": "Formato de ficheiro"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ADVERTENCIA",
|
"message": "ADVERTENCIA",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Erro"
|
"message": "Erro"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "יצוא כספת"
|
"message": "יצוא כספת"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "פורמט קובץ"
|
"message": "פורמט קובץ"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "אזהרה",
|
"message": "אזהרה",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "שגיאה"
|
"message": "שגיאה"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "संदर्भ मेनू विकल्प दिखाएं"
|
"message": "संदर्भ मेनू विकल्प दिखाएं"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "सौरीकृत अंधेरा",
|
"message": "सौरीकृत अंधेरा",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export Vault"
|
"message": "Export Vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File Format"
|
"message": "File Format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "चेतावनी",
|
"message": "चेतावनी",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "एरर"
|
"message": "एरर"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Otključaj"
|
"message": "Otključaj"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Prikaži opcije kotekstualnog izbornika"
|
"message": "Prikaži opcije kotekstualnog izbornika"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Izvezi trezor"
|
"message": "Izvezi trezor"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Format datoteke"
|
"message": "Format datoteke"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "UPOZORENJE",
|
"message": "UPOZORENJE",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Pogreška"
|
"message": "Pogreška"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Feloldás"
|
"message": "Feloldás"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Kiegészítő opciók"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Helyi menü opciók megjelenítése"
|
"message": "Helyi menü opciók megjelenítése"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Szolarizált sötét",
|
"message": "Szolarizált sötét",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Exportálás innen:"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Széf exportálása"
|
"message": "Széf exportálása"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Fájlformátum"
|
"message": "Fájlformátum"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Ez a fájl exportálás jelszóval védett és a visszafejtéshez a fájl jelszó megadása szükséges."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Fájl jelszó"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Ezt a jelszó kerül használatba a fájl exportálására és importálására."
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Használjuk a fiók felhasználónevéből és mesterjelszavából származó fióktitkosítási kulcsot az exportálás titkosításához és az importálást csak az aktuális Bitwarden fiókra korlátozzuk."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Állítsunk be egy fájl jelszót az exportálás titkosításához és importáljuk azt bármely Bitwarden fiókba a visszafejtéshez használt jelszó használatával."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Exportálási típus"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Korlátozott fiók"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "A “Fájl jelszó” és a “Fájl jelszó megerősítés“ nem egyezik."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "FIGYELEM",
|
"message": "FIGYELEM",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Szervezeti széf exportálása"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Csak $ORGANIZATION$ névvel társított szervezeti széf kerül exportálásra. Ebbe nem kerülnek be a személyes és más szervezeti széf elemek.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Hiba"
|
"message": "Hiba"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Gelap Solarized",
|
"message": "Gelap Solarized",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Ekspor Brankas"
|
"message": "Ekspor Brankas"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Format Berkas"
|
"message": "Format Berkas"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "PERINGATAN",
|
"message": "PERINGATAN",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Galat"
|
"message": "Galat"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Sblocca"
|
"message": "Sblocca"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Opzioni aggiuntive"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Mostra opzioni nel menu contestuale"
|
"message": "Mostra opzioni nel menu contestuale"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Scuro solarizzato",
|
"message": "Scuro solarizzato",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Esporta da"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Esporta cassaforte"
|
"message": "Esporta cassaforte"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Formato file"
|
"message": "Formato file"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Questo file esportato sarà protetto e richiederà la password del file per decifrarlo."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Password del file"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "La password sarà utilizzata per importare ed esportare questo file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Usa la chiave di crittografia dell'account, derivata dal nome utente e dalla password principale del tuo account, per crittografare il file di esportazione e limitare l'importazione solo all'account Bitwarden corrente."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Imposta una password del file per crittografare il file esportato e importarlo in qualsiasi account Bitwarden usando la password per decrittografarlo."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Tipo di esportazione"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account limitato"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "Le due password del file non corrispondono."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ATTENZIONE",
|
"message": "ATTENZIONE",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Esportando cassaforte dell'organizzazione"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Solo la cassaforte dell'organizzazione associata a $ORGANIZATION$ sarà esportata. Elementi nelle casseforti individuali o in altre organizzazioni non saranno inclusi.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Errore"
|
"message": "Errore"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "ロック解除"
|
"message": "ロック解除"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "追加オプション"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "コンテキストメニューオプションを表示"
|
"message": "コンテキストメニューオプションを表示"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized ダーク",
|
"message": "Solarized ダーク",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "エクスポート元"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "保管庫のエクスポート"
|
"message": "保管庫のエクスポート"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "ファイル形式"
|
"message": "ファイル形式"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "エクスポートするファイルはパスワードで保護され、復号するにはファイルパスワードが必要になります。"
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "ファイルパスワード"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "このパスワードはこのファイルのエクスポートとインポート時に使用します"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "アカウントのユーザー名とマスターパスワードから得られる暗号化キーを使用してエクスポートするデータを暗号化し、現在の Bitwarden アカウントのみがインポートできるよう制限します。"
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "エクスポートを暗号化するためのファイルパスワードを設定します。そのパスワードを使用して、任意の Bitwarden アカウントにインポートします。"
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "エクスポートの種類"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "アカウント制限"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "「ファイルパスワード」と「ファイルパスワードの確認」が一致しません。"
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "警告",
|
"message": "警告",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "組織保管庫のエクスポート"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "$ORGANIZATION$ に関連付けられた組織保管庫のみがエクスポートされます。個々の保管庫または他の組織にあるアイテムは含まれません。",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "エラー"
|
"message": "エラー"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "ಡಾರ್ಕ್ ಸೌರ",
|
"message": "ಡಾರ್ಕ್ ಸೌರ",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "ರಫ್ತು ವಾಲ್ಟ್"
|
"message": "ರಫ್ತು ವಾಲ್ಟ್"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "ಕಡತದ ಮಾದರಿ"
|
"message": "ಕಡತದ ಮಾದರಿ"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ಎಚ್ಚರಿಕೆ",
|
"message": "ಎಚ್ಚರಿಕೆ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "잠금 해제"
|
"message": "잠금 해제"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "보관함 내보내기"
|
"message": "보관함 내보내기"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "파일 형식"
|
"message": "파일 형식"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "경고",
|
"message": "경고",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "오류"
|
"message": "오류"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -423,7 +423,7 @@
|
|||||||
"message": "Kita"
|
"message": "Kita"
|
||||||
},
|
},
|
||||||
"unlockMethods": {
|
"unlockMethods": {
|
||||||
"message": "Unlock options"
|
"message": "Atrakinti parinktis"
|
||||||
},
|
},
|
||||||
"unlockMethodNeededToChangeTimeoutActionDesc": {
|
"unlockMethodNeededToChangeTimeoutActionDesc": {
|
||||||
"message": "Nustatyk atrakinimo būdą, kad pakeistum saugyklos laiko limito veiksmą."
|
"message": "Nustatyk atrakinimo būdą, kad pakeistum saugyklos laiko limito veiksmą."
|
||||||
@@ -432,10 +432,10 @@
|
|||||||
"message": "Nustatykite nustatymuose atrakinimo metodą"
|
"message": "Nustatykite nustatymuose atrakinimo metodą"
|
||||||
},
|
},
|
||||||
"sessionTimeoutHeader": {
|
"sessionTimeoutHeader": {
|
||||||
"message": "Session timeout"
|
"message": "Baigėsi seanso laikas"
|
||||||
},
|
},
|
||||||
"otherOptions": {
|
"otherOptions": {
|
||||||
"message": "Other options"
|
"message": "Kitos parinktys"
|
||||||
},
|
},
|
||||||
"rateExtension": {
|
"rateExtension": {
|
||||||
"message": "Įvertinkite šį plėtinį"
|
"message": "Įvertinkite šį plėtinį"
|
||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Atrakinti"
|
"message": "Atrakinti"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Rodyti kontekstinio meniu pasririnkimus"
|
"message": "Rodyti kontekstinio meniu pasririnkimus"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Saulėtas tamsą",
|
"message": "Saulėtas tamsą",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Eksportuoti saugyklą"
|
"message": "Eksportuoti saugyklą"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Failo formatas"
|
"message": "Failo formatas"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ĮSPĖJIMAS",
|
"message": "ĮSPĖJIMAS",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Klaida"
|
"message": "Klaida"
|
||||||
},
|
},
|
||||||
@@ -2232,7 +2274,7 @@
|
|||||||
"message": "Sugeneruoti el. pašto slapyvardį su išorine persiuntimo paslauga."
|
"message": "Sugeneruoti el. pašto slapyvardį su išorine persiuntimo paslauga."
|
||||||
},
|
},
|
||||||
"forwarderError": {
|
"forwarderError": {
|
||||||
"message": "$SERVICENAME$ error: $ERRORMESSAGE$",
|
"message": "„$SERVICENAME$“ klaida: $ERRORMESSAGE$.",
|
||||||
"description": "Reports an error returned by a forwarding service to the user.",
|
"description": "Reports an error returned by a forwarding service to the user.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"servicename": {
|
"servicename": {
|
||||||
@@ -2246,11 +2288,11 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"forwarderGeneratedBy": {
|
"forwarderGeneratedBy": {
|
||||||
"message": "Generated by Bitwarden.",
|
"message": "Sugeneravo „Bitwarden“.",
|
||||||
"description": "Displayed with the address on the forwarding service's configuration screen."
|
"description": "Displayed with the address on the forwarding service's configuration screen."
|
||||||
},
|
},
|
||||||
"forwarderGeneratedByWithWebsite": {
|
"forwarderGeneratedByWithWebsite": {
|
||||||
"message": "Website: $WEBSITE$. Generated by Bitwarden.",
|
"message": "Svetainė: $WEBSITE$. Sugeneravo „Bitwarden“.",
|
||||||
"description": "Displayed with the address on the forwarding service's configuration screen.",
|
"description": "Displayed with the address on the forwarding service's configuration screen.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"WEBSITE": {
|
"WEBSITE": {
|
||||||
@@ -2260,7 +2302,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"forwaderInvalidToken": {
|
"forwaderInvalidToken": {
|
||||||
"message": "Invalid $SERVICENAME$ API token",
|
"message": "Netinkamas „$SERVICENAME$“ API prieigos raktas.",
|
||||||
"description": "Displayed when the user's API token is empty or rejected by the forwarding service.",
|
"description": "Displayed when the user's API token is empty or rejected by the forwarding service.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"servicename": {
|
"servicename": {
|
||||||
@@ -2270,7 +2312,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"forwaderInvalidTokenWithMessage": {
|
"forwaderInvalidTokenWithMessage": {
|
||||||
"message": "Invalid $SERVICENAME$ API token: $ERRORMESSAGE$",
|
"message": "Netinkamas „$SERVICENAME$“ API prieigos raktas: $ERRORMESSAGE$.",
|
||||||
"description": "Displayed when the user's API token is rejected by the forwarding service with an error message.",
|
"description": "Displayed when the user's API token is rejected by the forwarding service with an error message.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"servicename": {
|
"servicename": {
|
||||||
@@ -2284,7 +2326,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"forwarderNoAccountId": {
|
"forwarderNoAccountId": {
|
||||||
"message": "Unable to obtain $SERVICENAME$ masked email account ID.",
|
"message": "Nepavyksta gauti „$SERVICENAME$“ užmaskuoto el. pašto paskyros ID.",
|
||||||
"description": "Displayed when the forwarding service fails to return an account ID.",
|
"description": "Displayed when the forwarding service fails to return an account ID.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"servicename": {
|
"servicename": {
|
||||||
@@ -2294,7 +2336,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"forwarderNoDomain": {
|
"forwarderNoDomain": {
|
||||||
"message": "Invalid $SERVICENAME$ domain.",
|
"message": "Netinkamas „$SERVICENAME$“ domenas.",
|
||||||
"description": "Displayed when the domain is empty or domain authorization failed at the forwarding service.",
|
"description": "Displayed when the domain is empty or domain authorization failed at the forwarding service.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"servicename": {
|
"servicename": {
|
||||||
@@ -2304,7 +2346,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"forwarderNoUrl": {
|
"forwarderNoUrl": {
|
||||||
"message": "Invalid $SERVICENAME$ url.",
|
"message": "Netinkamas „$SERVICENAME$“ URL.",
|
||||||
"description": "Displayed when the url of the forwarding service wasn't supplied.",
|
"description": "Displayed when the url of the forwarding service wasn't supplied.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"servicename": {
|
"servicename": {
|
||||||
@@ -2314,7 +2356,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"forwarderUnknownError": {
|
"forwarderUnknownError": {
|
||||||
"message": "Unknown $SERVICENAME$ error occurred.",
|
"message": "Įvyko nežinoma „$SERVICENAME$“ klaida.",
|
||||||
"description": "Displayed when the forwarding service failed due to an unknown error.",
|
"description": "Displayed when the forwarding service failed due to an unknown error.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"servicename": {
|
"servicename": {
|
||||||
@@ -2324,7 +2366,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"forwarderUnknownForwarder": {
|
"forwarderUnknownForwarder": {
|
||||||
"message": "Unknown forwarder: '$SERVICENAME$'.",
|
"message": "Nežinomas persiuntėjas: „$SERVICENAME$“.",
|
||||||
"description": "Displayed when the forwarding service is not supported.",
|
"description": "Displayed when the forwarding service is not supported.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"servicename": {
|
"servicename": {
|
||||||
@@ -3245,13 +3287,13 @@
|
|||||||
"message": "Administratoriaus konsolės"
|
"message": "Administratoriaus konsolės"
|
||||||
},
|
},
|
||||||
"accountSecurity": {
|
"accountSecurity": {
|
||||||
"message": "Account security"
|
"message": "Paskyros saugumas"
|
||||||
},
|
},
|
||||||
"notifications": {
|
"notifications": {
|
||||||
"message": "Notifications"
|
"message": "Pranešimai"
|
||||||
},
|
},
|
||||||
"appearance": {
|
"appearance": {
|
||||||
"message": "Appearance"
|
"message": "Išvaizda"
|
||||||
},
|
},
|
||||||
"errorAssigningTargetCollection": {
|
"errorAssigningTargetCollection": {
|
||||||
"message": "Klaida priskiriant tikslinę kolekciją."
|
"message": "Klaida priskiriant tikslinę kolekciją."
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Atslēgt"
|
"message": "Atslēgt"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Papildu iespējas"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Rādīt konteksta izvēlnes iespējas"
|
"message": "Rādīt konteksta izvēlnes iespējas"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Izgūt no"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Izgūt glabātavas saturu"
|
"message": "Izgūt glabātavas saturu"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Datnes veids"
|
"message": "Datnes veids"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Šī datņu izgūšana būs aizsargāta ar paroli, un būs nepieciešama datnes parole, lai to atšifrētu."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Datnes parole"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Šī parole tiks izmantota, lai izgūtu un ievietotu šo datni"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Jāizmanto konta šifrēšanas atslēga, kas iegūta no lietotājvārda un galvenās paroles, lai šifrētu izguvi un atļautu ievietošanu tikai pašreizējā Bitwarden kontā."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Uzstādīt paroli, lai šifrētu izguvi un tad to ievietotu jebkurā Bitwarden kontā, izmantojot atšifrēšanas paroli."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Izgūšanas veids"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Konts ir ierobežots"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Datnes parole\" un \"Apstiprināt datnes paroli\" vērtības nesakrīt."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "UZMANĪBU",
|
"message": "UZMANĪBU",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -813,7 +843,7 @@
|
|||||||
"message": "Apstiprināt glabātavas satura izgūšanu"
|
"message": "Apstiprināt glabātavas satura izgūšanu"
|
||||||
},
|
},
|
||||||
"exportWarningDesc": {
|
"exportWarningDesc": {
|
||||||
"message": "Šī izguve satur glabātavas datus nešifrētā veidā. Izdoto datni nevajadzētu glabāt vai sūtīt nedrošos veidos (piemēram, e-pastā). Izdzēst to uzreiz pēc izmantošanas."
|
"message": "Šī izguve satur glabātavas datus nešifrētā veidā. Izgūto datni nevajadzētu glabāt vai sūtīt nedrošos veidos (piemēram, e-pastā). Tā ir jāizdzēš uzreiz pēc izmantošanas."
|
||||||
},
|
},
|
||||||
"encExportKeyWarningDesc": {
|
"encExportKeyWarningDesc": {
|
||||||
"message": "Šī izguve šifrē datus ar konta šifrēšanas atslēgu. Ja tā jebkad tiks mainīta, izvadi vajadzētu veikt vēlreiz, jo vairs nebūs iespējams atšifrēt šo datni."
|
"message": "Šī izguve šifrē datus ar konta šifrēšanas atslēgu. Ja tā jebkad tiks mainīta, izvadi vajadzētu veikt vēlreiz, jo vairs nebūs iespējams atšifrēt šo datni."
|
||||||
@@ -2171,7 +2201,7 @@
|
|||||||
"message": "Sesijai iestājās noildze. Lūgums mēģināt pieteikties vēlreiz."
|
"message": "Sesijai iestājās noildze. Lūgums mēģināt pieteikties vēlreiz."
|
||||||
},
|
},
|
||||||
"exportingPersonalVaultTitle": {
|
"exportingPersonalVaultTitle": {
|
||||||
"message": "Izdod personīgo glabātavu"
|
"message": "Izgūst personīgo glabātavu"
|
||||||
},
|
},
|
||||||
"exportingIndividualVaultDescription": {
|
"exportingIndividualVaultDescription": {
|
||||||
"message": "Tiks izgūti tikai atsevišķi glabātavas vienumi, kas ir saistīti ar $EMAIL$. Apvienības glabātavas vienumi netiks iekļauti. Tiks izgūta tikai glabātavas vienumu informācija, un saistītie pielikumi netiks iekļauti.",
|
"message": "Tiks izgūti tikai atsevišķi glabātavas vienumi, kas ir saistīti ar $EMAIL$. Apvienības glabātavas vienumi netiks iekļauti. Tiks izgūta tikai glabātavas vienumu informācija, un saistītie pielikumi netiks iekļauti.",
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Izgūst apvienības glabātavu"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Tiks izgūta tikai apvienības glabātava, kas ir saistīta ar $ORGANIZATION$. Atsevišķu glabātavu vai citu apvienību vienumi netiks iekļauti.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Kļūda"
|
"message": "Kļūda"
|
||||||
},
|
},
|
||||||
@@ -2907,7 +2949,7 @@
|
|||||||
"message": "Kļūda izguves datnes atšifrēšanā. Izmantotā atslēga neatbilst tai, kas tika izmantota satura izgūšanai."
|
"message": "Kļūda izguves datnes atšifrēšanā. Izmantotā atslēga neatbilst tai, kas tika izmantota satura izgūšanai."
|
||||||
},
|
},
|
||||||
"invalidFilePassword": {
|
"invalidFilePassword": {
|
||||||
"message": "Nederīga datnes parole, lūgums izmantot to paroli, kas tika ievadīta izdošanas datnes izveidošanas brīdī."
|
"message": "Nederīga datnes parole, lūgums izmantot to paroli, kas tika ievadīta izgūšanas datnes izveidošanas brīdī."
|
||||||
},
|
},
|
||||||
"importDestination": {
|
"importDestination": {
|
||||||
"message": "Ievietošanas galamērķis"
|
"message": "Ievietošanas galamērķis"
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "വാൾട് എക്സ്പോർട്"
|
"message": "വാൾട് എക്സ്പോർട്"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "ഫയൽ ഫോർമാറ്റ്"
|
"message": "ഫയൽ ഫോർമാറ്റ്"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "മുന്നറിയിപ്പ്",
|
"message": "മുന്നറിയിപ്പ്",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Lås opp"
|
"message": "Lås opp"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Vis alternativer for kontekstmeny"
|
"message": "Vis alternativer for kontekstmeny"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarisert mørk",
|
"message": "Solarisert mørk",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Eksporter hvelvet"
|
"message": "Eksporter hvelvet"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Filformat"
|
"message": "Filformat"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ADVARSEL",
|
"message": "ADVARSEL",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Feil"
|
"message": "Feil"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Ontgrendelen"
|
"message": "Ontgrendelen"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Extra instellingen"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Contextmenu-opties weergeven"
|
"message": "Contextmenu-opties weergeven"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Overbelicht donker",
|
"message": "Overbelicht donker",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Exporteren vanuit"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Kluis exporteren"
|
"message": "Kluis exporteren"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Bestandsindeling"
|
"message": "Bestandsindeling"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "We beveiligen deze bestandsexport met een wachtwoord beveiligd, je hebt het bestandswachtwoord nodig om het te decoderen."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Bestandswachtwoord"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "We gebruiken dit wachtwoord bij het exporteren en importeren van dit bestand"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Gebruik de encryptiesleutel van je account, afgeleid van je gebruikersnaam en hoodfwachtwoord, om de export te versleutelen en importeren te beperken tot het huidige Bitwarden-account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Stel een bestandswachtwoord in om de export te versleutelen en te importeren naar een willekeurig Bitwarden-account met het wachtwoord voor decoderen."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Exporttype"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account beperkt"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Bestandswachtwoord\" en \"Bestandswachtwoord bevestigen\" komen niet overeen."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WAARSCHUWING",
|
"message": "WAARSCHUWING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Organisatiekluis exporteren"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Exporteert alleen de organisatiekluis van $ORGANIZATION$. Geen persoonlijke kluis-items of items van andere organisaties.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Fout"
|
"message": "Fout"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Odblokuj"
|
"message": "Odblokuj"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Dodatkowe opcje"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Pokaż opcje menu kontekstowego"
|
"message": "Pokaż opcje menu kontekstowego"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Eksportuj z"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Eksportuj sejf"
|
"message": "Eksportuj sejf"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Format pliku"
|
"message": "Format pliku"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Plik będzie chroniony hasłem, które będzie wymagane do odszyfrowania pliku."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Hasło do pliku"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Hasło będzie używane do eksportowania i importowania pliku"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Użyj klucza szyfrowania konta, pochodzącego z nazwy użytkownika konta i hasła głównego, aby zaszyfrować eksport i ograniczyć import tylko do bieżącego konta Bitwarden."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Ustaw hasło dla pliku, aby zaszyfrować eksport i zaimportować je na dowolne konto Bitwarden przy użyciu hasła do odszyfrowania."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Rodzaj eksportu"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Konto ograniczone"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“Hasło pliku” i “Potwierdź hasło pliku“ nie pasują do siebie."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "UWAGA",
|
"message": "UWAGA",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Eksportowanie sejfu organizacji"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Tylko sejf organizacji powiązany z $ORGANIZATION$ zostanie wyeksportowany. Pozycje w poszczególnych sejfach lub innych organizacji nie będą uwzględnione.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Błąd"
|
"message": "Błąd"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Desbloquear"
|
"message": "Desbloquear"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Mostrar opções de menu de contexto"
|
"message": "Mostrar opções de menu de contexto"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized (escuro)",
|
"message": "Solarized (escuro)",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Exportar Cofre"
|
"message": "Exportar Cofre"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Formato de arquivo"
|
"message": "Formato de arquivo"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "AVISO",
|
"message": "AVISO",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Erro"
|
"message": "Erro"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Desbloquear"
|
"message": "Desbloquear"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Opções adicionais"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Mostrar opções do menu de contexto"
|
"message": "Mostrar opções do menu de contexto"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized (escuro)",
|
"message": "Solarized (escuro)",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Exportar de"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Exportar cofre"
|
"message": "Exportar cofre"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Formato do ficheiro"
|
"message": "Formato do ficheiro"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "A exportação deste ficheiro será protegida por uma palavra-passe e exigirá a palavra-passe do ficheiro para ser desencriptada."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Palavra-passe do ficheiro"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Esta palavra-passe será utilizada para exportar e importar este ficheiro"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Utilize a chave de encriptação da sua conta, derivada do nome de utilizador e da palavra-passe mestra da sua conta, para encriptar a exportação e restringir a importação apenas à conta Bitwarden atual."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Defina uma palavra-passe do ficheiro para encriptar a exportação e importe-a para qualquer conta Bitwarden utilizando a palavra-passe de desencriptação."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Tipo de exportação"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Conta restringida"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Palavra-passe do ficheiro\" e \"Confirmar palavra-passe do ficheiro\" não correspondem."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "AVISO",
|
"message": "AVISO",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "A exportar o cofre da organização"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Apenas o cofre da organização associado a $ORGANIZATION$ será exportado. Os itens em cofres individuais ou noutras organizações não serão incluídos.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Erro"
|
"message": "Erro"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Deblocare"
|
"message": "Deblocare"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Afișați opțiunile meniului contextual"
|
"message": "Afișați opțiunile meniului contextual"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Întuneric solarizat",
|
"message": "Întuneric solarizat",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export seif"
|
"message": "Export seif"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Format fișier"
|
"message": "Format fișier"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "AVERTISMENT",
|
"message": "AVERTISMENT",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Eroare"
|
"message": "Eroare"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Разблокировать"
|
"message": "Разблокировать"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Показать опции контекстного меню"
|
"message": "Показать опции контекстного меню"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Экспорт из"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Экспорт хранилища"
|
"message": "Экспорт хранилища"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Формат файла"
|
"message": "Формат файла"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Экспорт этого файла будет защищен паролем, и для расшифровки потребуется пароль файла."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Пароль к файлу"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Этот пароль будет использоваться для экспорта и импорта этого файла"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Использовать ключ шифрования вашего аккаунта, полученный из имени пользователя и мастер-пароля, для шифрования экспорта и ограничения импорта только для текущего аккаунта Bitwarden."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Установите пароль файла для шифрования экспорта и импортируйте его в любую учетную запись Bitwarden, используя пароль для расшифровки."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Тип экспорта"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Ограничено аккаунтом"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Пароль к файлу\" и \"Подтверждение пароля к файлу\" не совпадают."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ВНИМАНИЕ",
|
"message": "ВНИМАНИЕ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Экспорт хранилища организации"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Будет экспортировано только хранилище организации, связанное с $ORGANIZATION$. Элементы из личных хранилищ и из других организаций включены не будут.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Ошибка"
|
"message": "Ошибка"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "අඳුරු අඳුරු",
|
"message": "අඳුරු අඳුරු",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "අපනයන සුරක්ෂිතාගාරය"
|
"message": "අපනයන සුරක්ෂිතාගාරය"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "ගොනු ආකෘතිය"
|
"message": "ගොනු ආකෘතිය"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "අවවාදයයි",
|
"message": "අවවාදයයි",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Odomknúť"
|
"message": "Odomknúť"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Ďalšie možnosti"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Zobraziť možnosti kontextovej ponuky"
|
"message": "Zobraziť možnosti kontextovej ponuky"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized – tmavý",
|
"message": "Solarized – tmavý",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Exportovať z"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export trezoru"
|
"message": "Export trezoru"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Formát Súboru"
|
"message": "Formát Súboru"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Tento exportovaný súbor bude chránený heslom a na dešifrovanie bude potrebné heslo súboru."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Heslo súboru"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Toto heslo sa použije na export a import tohto súboru"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Na zašifrovanie exportu a obmedzenie importu len na aktuálny účet Bitwarden použite šifrovací kľúč účtu odvodený z používateľského mena a hlavného hesla účtu."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Nastavte heslo súboru na zašifrovanie exportu a importujte ho do akéhokoľvek účtu Bitwarden pomocou hesla na dešifrovanie."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Typ exportu"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Obmedzený účet"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Heslo súboru\" a \"Potvrdiť heslo súboru\" sa nezhodujú."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "UPOZORNENIE",
|
"message": "UPOZORNENIE",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exportovanie trezora organizácie"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Exportované budú iba položky trezora organizácie spojené s $ORGANIZATION$. Položky osobného trezora a položky z iných organizácií nebudú zahrnuté.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Chyba"
|
"message": "Chyba"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Prikaži možnosti kontekstnega menuja"
|
"message": "Prikaži možnosti kontekstnega menuja"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Izvoz trezorja"
|
"message": "Izvoz trezorja"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Format datoteke"
|
"message": "Format datoteke"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "OPOZORILO",
|
"message": "OPOZORILO",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Napaka"
|
"message": "Napaka"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Откључај"
|
"message": "Откључај"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Прикажи контекстни мени"
|
"message": "Прикажи контекстни мени"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized црно",
|
"message": "Solarized црно",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Извоз сефа"
|
"message": "Извоз сефа"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Формат датотеке"
|
"message": "Формат датотеке"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "УПОЗОРЕЊЕ",
|
"message": "УПОЗОРЕЊЕ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Грешка"
|
"message": "Грешка"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Lås upp"
|
"message": "Lås upp"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Ytterligare alternativ"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Visa alternativ för snabbmenyn"
|
"message": "Visa alternativ för snabbmenyn"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized mörk",
|
"message": "Solarized mörk",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Exportera från"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Exportera valv"
|
"message": "Exportera valv"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Filformat"
|
"message": "Filformat"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Fillösenord"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Exporttyp"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "VARNING",
|
"message": "VARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Fel"
|
"message": "Fel"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Show context menu options"
|
"message": "Show context menu options"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized dark",
|
"message": "Solarized dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export vault"
|
"message": "Export vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File format"
|
"message": "File format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "WARNING",
|
"message": "WARNING",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Unlock"
|
"message": "Unlock"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "แสดงตัวเลือกเมนูบริบท"
|
"message": "แสดงตัวเลือกเมนูบริบท"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Export Vault"
|
"message": "Export Vault"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File Format"
|
"message": "File Format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "คำเตือน",
|
"message": "คำเตือน",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Error"
|
"message": "Error"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -185,7 +185,7 @@
|
|||||||
"message": "Tarayıcınızın uzantı sitesine gitmek ister misiniz?"
|
"message": "Tarayıcınızın uzantı sitesine gitmek ister misiniz?"
|
||||||
},
|
},
|
||||||
"continueToBrowserExtensionStoreDesc": {
|
"continueToBrowserExtensionStoreDesc": {
|
||||||
"message": "Help others find out if Bitwarden is right for them. Visit your browser's extension store and leave a rating now."
|
"message": "Bitwarden'ı başkalarına da tanımak ister misiniz? Tarayıcınızın uzantı mağazasını ziyaret edip Bitwarden'ı değerlendirin."
|
||||||
},
|
},
|
||||||
"changeMasterPasswordOnWebConfirmation": {
|
"changeMasterPasswordOnWebConfirmation": {
|
||||||
"message": "Ana parolanızı Bitwarden web uygulamasında değiştirebilirsiniz."
|
"message": "Ana parolanızı Bitwarden web uygulamasında değiştirebilirsiniz."
|
||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Kilidi aç"
|
"message": "Kilidi aç"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Ek seçenekler"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Bağlam menüsü seçeneklerini göster"
|
"message": "Bağlam menüsü seçeneklerini göster"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized koyu",
|
"message": "Solarized koyu",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Kasayı dışa aktar"
|
"message": "Kasayı dışa aktar"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Dosya biçimi"
|
"message": "Dosya biçimi"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Dosya parolası"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Bu parola, bu dosyayı dışa ve içe aktarmak için kullanılacaktır"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Dışa aktarmayı şifrelemek ve içe aktarmayı yalnızca mevcut Bitwarden hesabıyla kısıtlamak için, hesabınızın kullanıcı adı ve ana parolasından türetilen hesap şifreleme anahtarınızı kullanın."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Dışa aktardığınız dosyayı şifrelemek ve bir Bitwarden hesabına içe aktarmak için kullanacağınız parolayı belirleyin."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Dışa aktarma türü"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Hesap kısıtlı"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "\"Dosya parolası\" ile \"Dosya parolasını onaylayın\" eşleşmiyor."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "UYARI",
|
"message": "UYARI",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Kuruluş kasasını dışa aktarma"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Hata"
|
"message": "Hata"
|
||||||
},
|
},
|
||||||
@@ -2548,7 +2590,7 @@
|
|||||||
"message": "Creating account on"
|
"message": "Creating account on"
|
||||||
},
|
},
|
||||||
"checkYourEmail": {
|
"checkYourEmail": {
|
||||||
"message": "Check your email"
|
"message": "E-postanızı kontrol edin"
|
||||||
},
|
},
|
||||||
"followTheLinkInTheEmailSentTo": {
|
"followTheLinkInTheEmailSentTo": {
|
||||||
"message": "Follow the link in the email sent to"
|
"message": "Follow the link in the email sent to"
|
||||||
@@ -2560,10 +2602,10 @@
|
|||||||
"message": "No email?"
|
"message": "No email?"
|
||||||
},
|
},
|
||||||
"goBack": {
|
"goBack": {
|
||||||
"message": "Go back"
|
"message": "Geri dönüp"
|
||||||
},
|
},
|
||||||
"toEditYourEmailAddress": {
|
"toEditYourEmailAddress": {
|
||||||
"message": "to edit your email address."
|
"message": "e-posta adresinizi düzenleyin."
|
||||||
},
|
},
|
||||||
"eu": {
|
"eu": {
|
||||||
"message": "AB",
|
"message": "AB",
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Розблокувати"
|
"message": "Розблокувати"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Додаткові налаштування"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Показувати в контекстному меню"
|
"message": "Показувати в контекстному меню"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized темна",
|
"message": "Solarized темна",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Експортувати з"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Експортувати сховище"
|
"message": "Експортувати сховище"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "Формат файлу"
|
"message": "Формат файлу"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "Цей експортований файл буде захищений паролем, який необхідно ввести для його розшифрування."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "Пароль файлу"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "Цей пароль буде використано для експортування та імпортування цього файлу"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Використовуйте ключ шифрування свого облікового запису, створений на основі імені користувача й головного пароля, щоб зашифрувати експортовані дані та обмежити можливість імпортування лише до поточного облікового запису Bitwarden."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Встановіть пароль файлу, щоб зашифрувати експортовані дані та імпортувати до будь-якого облікового запису Bitwarden за допомогою цього пароля."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Тип експорту"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Обмежено обліковим записом"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "Пароль файлу та підтвердження пароля відрізняються."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "ПОПЕРЕДЖЕННЯ",
|
"message": "ПОПЕРЕДЖЕННЯ",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Експортування сховища організації"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Буде експортовано лише сховище організації, пов'язане з $ORGANIZATION$. Елементи особистих сховищ або інших організацій не будуть включені.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Помилка"
|
"message": "Помилка"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "Mở khóa"
|
"message": "Mở khóa"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "Hiển thị tuỳ chọn menu ngữ cảnh"
|
"message": "Hiển thị tuỳ chọn menu ngữ cảnh"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark",
|
"message": "Solarized Dark",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "Xuất kho lưu trữ"
|
"message": "Xuất kho lưu trữ"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "File Format"
|
"message": "File Format"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "CẢNH BÁO",
|
"message": "CẢNH BÁO",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "Lỗi"
|
"message": "Lỗi"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "解锁"
|
"message": "解锁"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "附加选项"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "显示上下文菜单选项"
|
"message": "显示上下文菜单选项"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "过曝暗",
|
"message": "过曝暗",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "导出自"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "导出密码库"
|
"message": "导出密码库"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "文件格式"
|
"message": "文件格式"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "此文件导出将受密码保护,需要文件密码才能解密。"
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "文件密码"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "此密码将用于导出和导入此文件"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "使用衍生自您账户的用户名和主密码的账户加密密钥,以加密此导出并限制只能导入到当前的 Bitwarden 账户。"
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "设置一个文件密码用来加密此导出,并使用此密码解密以导入到任意 Bitwarden 账户。"
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "导出类型"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "账户受限"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "「文件密码」与「确认文件密码」不一致。"
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "警告",
|
"message": "警告",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "正在导出组织密码库"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "仅会导出与 $ORGANIZATION$ 关联的组织密码库数据。不包括个人密码库和其他组织中的项目。",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "错误"
|
"message": "错误"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -762,6 +762,9 @@
|
|||||||
"notificationUnlock": {
|
"notificationUnlock": {
|
||||||
"message": "解鎖"
|
"message": "解鎖"
|
||||||
},
|
},
|
||||||
|
"additionalOptions": {
|
||||||
|
"message": "Additional options"
|
||||||
|
},
|
||||||
"enableContextMenuItem": {
|
"enableContextMenuItem": {
|
||||||
"message": "顯示內容選單選項"
|
"message": "顯示內容選單選項"
|
||||||
},
|
},
|
||||||
@@ -799,12 +802,39 @@
|
|||||||
"message": "Solarized Dark 主題",
|
"message": "Solarized Dark 主題",
|
||||||
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
"description": "'Solarized' is a noun and the name of a color scheme. It should not be translated."
|
||||||
},
|
},
|
||||||
|
"exportFrom": {
|
||||||
|
"message": "Export from"
|
||||||
|
},
|
||||||
"exportVault": {
|
"exportVault": {
|
||||||
"message": "匯出密碼庫"
|
"message": "匯出密碼庫"
|
||||||
},
|
},
|
||||||
"fileFormat": {
|
"fileFormat": {
|
||||||
"message": "檔案格式"
|
"message": "檔案格式"
|
||||||
},
|
},
|
||||||
|
"fileEncryptedExportWarningDesc": {
|
||||||
|
"message": "This file export will be password protected and require the file password to decrypt."
|
||||||
|
},
|
||||||
|
"filePassword": {
|
||||||
|
"message": "File password"
|
||||||
|
},
|
||||||
|
"exportPasswordDescription": {
|
||||||
|
"message": "This password will be used to export and import this file"
|
||||||
|
},
|
||||||
|
"accountRestrictedOptionDescription": {
|
||||||
|
"message": "Use your account encryption key, derived from your account's username and Master Password, to encrypt the export and restrict import to only the current Bitwarden account."
|
||||||
|
},
|
||||||
|
"passwordProtectedOptionDescription": {
|
||||||
|
"message": "Set a file password to encrypt the export and import it to any Bitwarden account using the password for decryption."
|
||||||
|
},
|
||||||
|
"exportTypeHeading": {
|
||||||
|
"message": "Export type"
|
||||||
|
},
|
||||||
|
"accountRestricted": {
|
||||||
|
"message": "Account restricted"
|
||||||
|
},
|
||||||
|
"filePasswordAndConfirmFilePasswordDoNotMatch": {
|
||||||
|
"message": "“File password” and “Confirm file password“ do not match."
|
||||||
|
},
|
||||||
"warning": {
|
"warning": {
|
||||||
"message": "警告",
|
"message": "警告",
|
||||||
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
"description": "WARNING (should stay in capitalized letters if the language permits)"
|
||||||
@@ -2182,6 +2212,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"exportingOrganizationVaultTitle": {
|
||||||
|
"message": "Exporting organization vault"
|
||||||
|
},
|
||||||
|
"exportingOrganizationVaultDesc": {
|
||||||
|
"message": "Only the organization vault associated with $ORGANIZATION$ will be exported. Items in individual vaults or other organizations will not be included.",
|
||||||
|
"placeholders": {
|
||||||
|
"organization": {
|
||||||
|
"content": "$1",
|
||||||
|
"example": "ACME Moving Co."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"message": "錯誤"
|
"message": "錯誤"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -144,7 +144,7 @@ describe("AutofillInit", () => {
|
|||||||
.mockResolvedValue(pageDetails);
|
.mockResolvedValue(pageDetails);
|
||||||
|
|
||||||
const response = await autofillInit["handleExtensionMessage"](message, sender, sendResponse);
|
const response = await autofillInit["handleExtensionMessage"](message, sender, sendResponse);
|
||||||
await Promise.resolve(response);
|
await flushPromises();
|
||||||
|
|
||||||
expect(response).toBe(true);
|
expect(response).toBe(true);
|
||||||
expect(sendResponse).toHaveBeenCalledWith(pageDetails);
|
expect(sendResponse).toHaveBeenCalledWith(pageDetails);
|
||||||
|
|||||||
@@ -37,14 +37,29 @@ describe("generateRandomCustomElementName", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe("sendExtensionMessage", () => {
|
describe("sendExtensionMessage", () => {
|
||||||
it("sends a message to the extention", () => {
|
it("sends a message to the extension", async () => {
|
||||||
const extensionMessageResponse = sendExtensionMessage("updateAutofillOverlayHidden", {
|
const extensionMessagePromise = sendExtensionMessage("updateAutofillOverlayHidden", {
|
||||||
display: "none",
|
display: "none",
|
||||||
});
|
});
|
||||||
jest.spyOn(chrome.runtime, "sendMessage");
|
|
||||||
|
|
||||||
expect(chrome.runtime.sendMessage).toHaveBeenCalled();
|
// Jest doesn't give anyway to select the typed overload of "sendMessage",
|
||||||
expect(extensionMessageResponse).toEqual(Promise.resolve({}));
|
// a cast is needed to get the correct spy type.
|
||||||
|
const sendMessageSpy = jest.spyOn(chrome.runtime, "sendMessage") as unknown as jest.SpyInstance<
|
||||||
|
void,
|
||||||
|
[message: string, responseCallback: (response: string) => void],
|
||||||
|
unknown
|
||||||
|
>;
|
||||||
|
|
||||||
|
expect(sendMessageSpy).toHaveBeenCalled();
|
||||||
|
|
||||||
|
const [latestCall] = sendMessageSpy.mock.calls;
|
||||||
|
const responseCallback = latestCall[1];
|
||||||
|
|
||||||
|
responseCallback("sendMessageResponse");
|
||||||
|
|
||||||
|
const response = await extensionMessagePromise;
|
||||||
|
|
||||||
|
expect(response).toEqual("sendMessageResponse");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ import {
|
|||||||
AuthRequestService,
|
AuthRequestService,
|
||||||
LoginEmailServiceAbstraction,
|
LoginEmailServiceAbstraction,
|
||||||
LoginEmailService,
|
LoginEmailService,
|
||||||
|
LogoutReason,
|
||||||
} from "@bitwarden/auth/common";
|
} from "@bitwarden/auth/common";
|
||||||
import { ApiService as ApiServiceAbstraction } from "@bitwarden/common/abstractions/api.service";
|
import { ApiService as ApiServiceAbstraction } from "@bitwarden/common/abstractions/api.service";
|
||||||
import { AuditService as AuditServiceAbstraction } from "@bitwarden/common/abstractions/audit.service";
|
import { AuditService as AuditServiceAbstraction } from "@bitwarden/common/abstractions/audit.service";
|
||||||
@@ -375,8 +376,17 @@ export default class MainBackground {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const logoutCallback = async (expired: boolean, userId?: UserId) =>
|
const logoutCallback = async (logoutReason: LogoutReason, userId?: UserId) =>
|
||||||
await this.logout(expired, userId);
|
await this.logout(logoutReason, userId);
|
||||||
|
|
||||||
|
const refreshAccessTokenErrorCallback = () => {
|
||||||
|
// Send toast to popup
|
||||||
|
this.messagingService.send("showToast", {
|
||||||
|
type: "error",
|
||||||
|
title: this.i18nService.t("errorRefreshingAccessToken"),
|
||||||
|
message: this.i18nService.t("errorRefreshingAccessTokenDesc"),
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
const isDev = process.env.ENV === "development";
|
const isDev = process.env.ENV === "development";
|
||||||
this.logService = new ConsoleLogService(isDev);
|
this.logService = new ConsoleLogService(isDev);
|
||||||
@@ -523,6 +533,7 @@ export default class MainBackground {
|
|||||||
this.keyGenerationService,
|
this.keyGenerationService,
|
||||||
this.encryptService,
|
this.encryptService,
|
||||||
this.logService,
|
this.logService,
|
||||||
|
logoutCallback,
|
||||||
);
|
);
|
||||||
|
|
||||||
const migrationRunner = new MigrationRunner(
|
const migrationRunner = new MigrationRunner(
|
||||||
@@ -608,9 +619,12 @@ export default class MainBackground {
|
|||||||
this.platformUtilsService,
|
this.platformUtilsService,
|
||||||
this.environmentService,
|
this.environmentService,
|
||||||
this.appIdService,
|
this.appIdService,
|
||||||
|
refreshAccessTokenErrorCallback,
|
||||||
|
this.logService,
|
||||||
|
(logoutReason: LogoutReason, userId?: UserId) => this.logout(logoutReason, userId),
|
||||||
this.vaultTimeoutSettingsService,
|
this.vaultTimeoutSettingsService,
|
||||||
(expired: boolean) => this.logout(expired),
|
|
||||||
);
|
);
|
||||||
|
|
||||||
this.domainSettingsService = new DefaultDomainSettingsService(this.stateProvider);
|
this.domainSettingsService = new DefaultDomainSettingsService(this.stateProvider);
|
||||||
this.fileUploadService = new FileUploadService(this.logService);
|
this.fileUploadService = new FileUploadService(this.logService);
|
||||||
this.cipherFileUploadService = new CipherFileUploadService(
|
this.cipherFileUploadService = new CipherFileUploadService(
|
||||||
@@ -1283,7 +1297,7 @@ export default class MainBackground {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async logout(expired: boolean, userId?: UserId) {
|
async logout(logoutReason: LogoutReason, userId?: UserId) {
|
||||||
const activeUserId = await firstValueFrom(
|
const activeUserId = await firstValueFrom(
|
||||||
this.accountService.activeAccount$.pipe(
|
this.accountService.activeAccount$.pipe(
|
||||||
map((a) => a?.id),
|
map((a) => a?.id),
|
||||||
@@ -1349,7 +1363,7 @@ export default class MainBackground {
|
|||||||
await logoutPromise;
|
await logoutPromise;
|
||||||
|
|
||||||
this.messagingService.send("doneLoggingOut", {
|
this.messagingService.send("doneLoggingOut", {
|
||||||
expired: expired,
|
logoutReason: logoutReason,
|
||||||
userId: userBeingLoggedOut,
|
userId: userBeingLoggedOut,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
"manifest_version": 2,
|
"manifest_version": 2,
|
||||||
"name": "__MSG_extName__",
|
"name": "__MSG_extName__",
|
||||||
"short_name": "__MSG_appName__",
|
"short_name": "__MSG_appName__",
|
||||||
"version": "2024.5.1",
|
"version": "2024.6.0",
|
||||||
"description": "__MSG_extDesc__",
|
"description": "__MSG_extDesc__",
|
||||||
"default_locale": "en",
|
"default_locale": "en",
|
||||||
"author": "Bitwarden Inc.",
|
"author": "Bitwarden Inc.",
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
"minimum_chrome_version": "102.0",
|
"minimum_chrome_version": "102.0",
|
||||||
"name": "__MSG_extName__",
|
"name": "__MSG_extName__",
|
||||||
"short_name": "__MSG_appName__",
|
"short_name": "__MSG_appName__",
|
||||||
"version": "2024.5.1",
|
"version": "2024.6.0",
|
||||||
"description": "__MSG_extDesc__",
|
"description": "__MSG_extDesc__",
|
||||||
"default_locale": "en",
|
"default_locale": "en",
|
||||||
"author": "Bitwarden Inc.",
|
"author": "Bitwarden Inc.",
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import { ChangeDetectorRef, Component, NgZone, OnDestroy, OnInit } from "@angula
|
|||||||
import { NavigationEnd, Router, RouterOutlet } from "@angular/router";
|
import { NavigationEnd, Router, RouterOutlet } from "@angular/router";
|
||||||
import { Subject, takeUntil, firstValueFrom, concatMap, filter, tap } from "rxjs";
|
import { Subject, takeUntil, firstValueFrom, concatMap, filter, tap } from "rxjs";
|
||||||
|
|
||||||
|
import { LogoutReason } from "@bitwarden/auth/common";
|
||||||
import { AccountService } from "@bitwarden/common/auth/abstractions/account.service";
|
import { AccountService } from "@bitwarden/common/auth/abstractions/account.service";
|
||||||
import { AuthService } from "@bitwarden/common/auth/abstractions/auth.service";
|
import { AuthService } from "@bitwarden/common/auth/abstractions/auth.service";
|
||||||
import { AuthenticationStatus } from "@bitwarden/common/auth/enums/authentication-status";
|
import { AuthenticationStatus } from "@bitwarden/common/auth/enums/authentication-status";
|
||||||
@@ -10,7 +11,12 @@ import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/pl
|
|||||||
import { MessageListener } from "@bitwarden/common/platform/messaging";
|
import { MessageListener } from "@bitwarden/common/platform/messaging";
|
||||||
import { UserId } from "@bitwarden/common/types/guid";
|
import { UserId } from "@bitwarden/common/types/guid";
|
||||||
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
||||||
import { DialogService, SimpleDialogOptions, ToastService } from "@bitwarden/components";
|
import {
|
||||||
|
DialogService,
|
||||||
|
SimpleDialogOptions,
|
||||||
|
ToastOptions,
|
||||||
|
ToastService,
|
||||||
|
} from "@bitwarden/components";
|
||||||
|
|
||||||
import { BrowserApi } from "../platform/browser/browser-api";
|
import { BrowserApi } from "../platform/browser/browser-api";
|
||||||
import { BrowserStateService } from "../platform/services/abstractions/browser-state.service";
|
import { BrowserStateService } from "../platform/services/abstractions/browser-state.service";
|
||||||
@@ -83,13 +89,10 @@ export class AppComponent implements OnInit, OnDestroy {
|
|||||||
.pipe(
|
.pipe(
|
||||||
tap((msg: any) => {
|
tap((msg: any) => {
|
||||||
if (msg.command === "doneLoggingOut") {
|
if (msg.command === "doneLoggingOut") {
|
||||||
|
// TODO: PM-8544 - why do we call logout in the popup after receiving the doneLoggingOut message? Hasn't this already completeted logout?
|
||||||
this.authService.logOut(async () => {
|
this.authService.logOut(async () => {
|
||||||
if (msg.expired) {
|
if (msg.logoutReason) {
|
||||||
this.toastService.showToast({
|
await this.displayLogoutReason(msg.logoutReason);
|
||||||
variant: "warning",
|
|
||||||
title: this.i18nService.t("loggedOut"),
|
|
||||||
message: this.i18nService.t("loginExpired"),
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
this.changeDetectorRef.detectChanges();
|
this.changeDetectorRef.detectChanges();
|
||||||
@@ -233,4 +236,23 @@ export class AppComponent implements OnInit, OnDestroy {
|
|||||||
this.browserSendStateService.setBrowserSendTypeComponentState(null),
|
this.browserSendStateService.setBrowserSendTypeComponentState(null),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Displaying toasts isn't super useful on the popup due to the reloads we do.
|
||||||
|
// However, it is visible for a moment on the FF sidebar logout.
|
||||||
|
private async displayLogoutReason(logoutReason: LogoutReason) {
|
||||||
|
let toastOptions: ToastOptions;
|
||||||
|
switch (logoutReason) {
|
||||||
|
case "invalidSecurityStamp":
|
||||||
|
case "sessionExpired": {
|
||||||
|
toastOptions = {
|
||||||
|
variant: "warning",
|
||||||
|
title: this.i18nService.t("loggedOut"),
|
||||||
|
message: this.i18nService.t("loginExpired"),
|
||||||
|
};
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.toastService.showToast(toastOptions);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -53,7 +53,9 @@ describe("Fido2 page script with native WebAuthn support", () => {
|
|||||||
const mockCredentialAssertResult = createAssertCredentialResultMock();
|
const mockCredentialAssertResult = createAssertCredentialResultMock();
|
||||||
setupMockedWebAuthnSupport();
|
setupMockedWebAuthnSupport();
|
||||||
|
|
||||||
require("./page-script");
|
beforeAll(() => {
|
||||||
|
require("./page-script");
|
||||||
|
});
|
||||||
|
|
||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
jest.resetModules();
|
jest.resetModules();
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
[title]="'autofillSuggestions' | i18n"
|
[title]="'autofillSuggestions' | i18n"
|
||||||
[showRefresh]="showRefresh"
|
[showRefresh]="showRefresh"
|
||||||
(onRefresh)="refreshCurrentTab()"
|
(onRefresh)="refreshCurrentTab()"
|
||||||
showAutoFill
|
showAutofillButton
|
||||||
></app-vault-list-items-container>
|
></app-vault-list-items-container>
|
||||||
<ng-container *ngIf="showEmptyAutofillTip$ | async">
|
<ng-container *ngIf="showEmptyAutofillTip$ | async">
|
||||||
<bit-section>
|
<bit-section>
|
||||||
|
|||||||
@@ -3,12 +3,12 @@ import { Component } from "@angular/core";
|
|||||||
import { combineLatest, map, Observable } from "rxjs";
|
import { combineLatest, map, Observable } from "rxjs";
|
||||||
|
|
||||||
import { JslibModule } from "@bitwarden/angular/jslib.module";
|
import { JslibModule } from "@bitwarden/angular/jslib.module";
|
||||||
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
|
||||||
import { IconButtonModule, SectionComponent, TypographyModule } from "@bitwarden/components";
|
import { IconButtonModule, SectionComponent, TypographyModule } from "@bitwarden/components";
|
||||||
|
|
||||||
import BrowserPopupUtils from "../../../../../platform/popup/browser-popup-utils";
|
import BrowserPopupUtils from "../../../../../platform/popup/browser-popup-utils";
|
||||||
import { PopupSectionHeaderComponent } from "../../../../../platform/popup/popup-section-header/popup-section-header.component";
|
import { PopupSectionHeaderComponent } from "../../../../../platform/popup/popup-section-header/popup-section-header.component";
|
||||||
import { VaultPopupItemsService } from "../../../services/vault-popup-items.service";
|
import { VaultPopupItemsService } from "../../../services/vault-popup-items.service";
|
||||||
|
import { PopupCipherView } from "../../../views/popup-cipher.view";
|
||||||
import { VaultListItemsContainerComponent } from "../vault-list-items-container/vault-list-items-container.component";
|
import { VaultListItemsContainerComponent } from "../vault-list-items-container/vault-list-items-container.component";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
@@ -30,7 +30,7 @@ export class AutofillVaultListItemsComponent {
|
|||||||
* The list of ciphers that can be used to autofill the current page.
|
* The list of ciphers that can be used to autofill the current page.
|
||||||
* @protected
|
* @protected
|
||||||
*/
|
*/
|
||||||
protected autofillCiphers$: Observable<CipherView[]> =
|
protected autofillCiphers$: Observable<PopupCipherView[]> =
|
||||||
this.vaultPopupItemsService.autoFillCiphers$;
|
this.vaultPopupItemsService.autoFillCiphers$;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -0,0 +1,77 @@
|
|||||||
|
<bit-item-action *ngIf="cipher.type === CipherType.Login">
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
bitIconButton="bwi-clone"
|
||||||
|
size="small"
|
||||||
|
[attr.aria-label]="'copyInfoLabel' | i18n: cipher.name"
|
||||||
|
[title]="'copyInfoTitle' | i18n: cipher.name"
|
||||||
|
[bitMenuTriggerFor]="loginOptions"
|
||||||
|
></button>
|
||||||
|
<bit-menu #loginOptions>
|
||||||
|
<button type="button" bitMenuItem appCopyField="username" [cipher]="cipher">
|
||||||
|
{{ "copyUsername" | i18n }}
|
||||||
|
</button>
|
||||||
|
<button type="button" bitMenuItem appCopyField="password" [cipher]="cipher">
|
||||||
|
{{ "copyPassword" | i18n }}
|
||||||
|
</button>
|
||||||
|
<button type="button" bitMenuItem appCopyField="totp" [cipher]="cipher">
|
||||||
|
{{ "copyVerificationCode" | i18n }}
|
||||||
|
</button>
|
||||||
|
</bit-menu>
|
||||||
|
</bit-item-action>
|
||||||
|
|
||||||
|
<bit-item-action *ngIf="cipher.type === CipherType.Card">
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
bitIconButton="bwi-clone"
|
||||||
|
size="small"
|
||||||
|
[attr.aria-label]="'copyInfoLabel' | i18n: cipher.name"
|
||||||
|
[title]="'copyInfoTitle' | i18n: cipher.name"
|
||||||
|
[bitMenuTriggerFor]="cardOptions"
|
||||||
|
></button>
|
||||||
|
<bit-menu #cardOptions>
|
||||||
|
<button type="button" bitMenuItem appCopyField="cardNumber" [cipher]="cipher">
|
||||||
|
{{ "copyNumber" | i18n }}
|
||||||
|
</button>
|
||||||
|
<button type="button" bitMenuItem appCopyField="securityCode" [cipher]="cipher">
|
||||||
|
{{ "copySecurityCode" | i18n }}
|
||||||
|
</button>
|
||||||
|
</bit-menu>
|
||||||
|
</bit-item-action>
|
||||||
|
|
||||||
|
<bit-item-action *ngIf="cipher.type === CipherType.Identity">
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
bitIconButton="bwi-clone"
|
||||||
|
size="small"
|
||||||
|
[attr.aria-label]="'copyInfoLabel' | i18n: cipher.name"
|
||||||
|
[title]="'copyInfoTitle' | i18n: cipher.name"
|
||||||
|
[bitMenuTriggerFor]="identityOptions"
|
||||||
|
></button>
|
||||||
|
<bit-menu #identityOptions>
|
||||||
|
<button type="button" bitMenuItem appCopyField="username" [cipher]="cipher">
|
||||||
|
{{ "copyUsername" | i18n }}
|
||||||
|
</button>
|
||||||
|
<button type="button" bitMenuItem appCopyField="email" [cipher]="cipher">
|
||||||
|
{{ "copyEmail" | i18n }}
|
||||||
|
</button>
|
||||||
|
<button type="button" bitMenuItem appCopyField="phone" [cipher]="cipher">
|
||||||
|
{{ "copyPhone" | i18n }}
|
||||||
|
</button>
|
||||||
|
<button type="button" bitMenuItem appCopyField="address" [cipher]="cipher">
|
||||||
|
{{ "copyAddress" | i18n }}
|
||||||
|
</button>
|
||||||
|
</bit-menu>
|
||||||
|
</bit-item-action>
|
||||||
|
|
||||||
|
<bit-item-action *ngIf="cipher.type === CipherType.SecureNote">
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
bitIconButton="bwi-clone"
|
||||||
|
size="small"
|
||||||
|
[attr.aria-label]="'copyNoteLabel' | i18n: cipher.name"
|
||||||
|
[title]="'copyNoteTitle' | i18n: cipher.name"
|
||||||
|
appCopyField="secureNote"
|
||||||
|
[cipher]="cipher"
|
||||||
|
></button>
|
||||||
|
</bit-item-action>
|
||||||
@@ -0,0 +1,29 @@
|
|||||||
|
import { CommonModule } from "@angular/common";
|
||||||
|
import { Component, Input } from "@angular/core";
|
||||||
|
|
||||||
|
import { JslibModule } from "@bitwarden/angular/jslib.module";
|
||||||
|
import { CipherType } from "@bitwarden/common/vault/enums";
|
||||||
|
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
||||||
|
import { IconButtonModule, ItemModule, MenuModule } from "@bitwarden/components";
|
||||||
|
import { CopyCipherFieldDirective } from "@bitwarden/vault";
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
standalone: true,
|
||||||
|
selector: "app-item-copy-actions",
|
||||||
|
templateUrl: "item-copy-actions.component.html",
|
||||||
|
imports: [
|
||||||
|
ItemModule,
|
||||||
|
IconButtonModule,
|
||||||
|
JslibModule,
|
||||||
|
MenuModule,
|
||||||
|
CommonModule,
|
||||||
|
CopyCipherFieldDirective,
|
||||||
|
],
|
||||||
|
})
|
||||||
|
export class ItemCopyActionsComponent {
|
||||||
|
@Input() cipher: CipherView;
|
||||||
|
|
||||||
|
protected CipherType = CipherType;
|
||||||
|
|
||||||
|
constructor() {}
|
||||||
|
}
|
||||||
@@ -0,0 +1,36 @@
|
|||||||
|
<bit-item-action>
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
bitIconButton="bwi-ellipsis-v"
|
||||||
|
size="small"
|
||||||
|
[attr.aria-label]="'moreOptionsLabel' | i18n: cipher.name"
|
||||||
|
[title]="'moreOptionsTitle' | i18n: cipher.name"
|
||||||
|
[bitMenuTriggerFor]="moreOptions"
|
||||||
|
></button>
|
||||||
|
<bit-menu #moreOptions>
|
||||||
|
<ng-container *ngIf="isLogin && !hideLoginOptions">
|
||||||
|
<ng-container *ngIf="autofillAllowed$ | async">
|
||||||
|
<button type="button" bitMenuItem>
|
||||||
|
{{ "autofill" | i18n }}
|
||||||
|
</button>
|
||||||
|
<button type="button" bitMenuItem *ngIf="canEdit">
|
||||||
|
{{ "fillAndSave" | i18n }}
|
||||||
|
</button>
|
||||||
|
</ng-container>
|
||||||
|
<button type="button" bitMenuItem *ngIf="this.canLaunch" (click)="launchCipher()">
|
||||||
|
{{ "launchWebsite" | i18n }}
|
||||||
|
</button>
|
||||||
|
</ng-container>
|
||||||
|
<button type="button" bitMenuItem (click)="toggleFavorite()">
|
||||||
|
{{ favoriteText | i18n }}
|
||||||
|
</button>
|
||||||
|
<ng-container *ngIf="canEdit">
|
||||||
|
<a routerLink="" bitMenuItem (click)="clone()">
|
||||||
|
{{ "clone" | i18n }}
|
||||||
|
</a>
|
||||||
|
<button type="button" bitMenuItem>
|
||||||
|
{{ "assignCollections" | i18n }}
|
||||||
|
</button>
|
||||||
|
</ng-container>
|
||||||
|
</bit-menu>
|
||||||
|
</bit-item-action>
|
||||||
@@ -0,0 +1,122 @@
|
|||||||
|
import { CommonModule } from "@angular/common";
|
||||||
|
import { booleanAttribute, Component, Input } from "@angular/core";
|
||||||
|
import { Router, RouterModule } from "@angular/router";
|
||||||
|
|
||||||
|
import { JslibModule } from "@bitwarden/angular/jslib.module";
|
||||||
|
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
||||||
|
import { CipherRepromptType, CipherType } from "@bitwarden/common/vault/enums";
|
||||||
|
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
||||||
|
import { DialogService, IconButtonModule, ItemModule, MenuModule } from "@bitwarden/components";
|
||||||
|
import { PasswordRepromptService } from "@bitwarden/vault";
|
||||||
|
|
||||||
|
import { BrowserApi } from "../../../../../platform/browser/browser-api";
|
||||||
|
import BrowserPopupUtils from "../../../../../platform/popup/browser-popup-utils";
|
||||||
|
import { VaultPopupItemsService } from "../../../services/vault-popup-items.service";
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
standalone: true,
|
||||||
|
selector: "app-item-more-options",
|
||||||
|
templateUrl: "./item-more-options.component.html",
|
||||||
|
imports: [ItemModule, IconButtonModule, MenuModule, CommonModule, JslibModule, RouterModule],
|
||||||
|
})
|
||||||
|
export class ItemMoreOptionsComponent {
|
||||||
|
@Input({
|
||||||
|
required: true,
|
||||||
|
})
|
||||||
|
cipher: CipherView;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flag to hide the login specific menu options. Used for login items that are
|
||||||
|
* already in the autofill list suggestion.
|
||||||
|
*/
|
||||||
|
@Input({ transform: booleanAttribute })
|
||||||
|
hideLoginOptions: boolean;
|
||||||
|
|
||||||
|
protected autofillAllowed$ = this.vaultPopupItemsService.autofillAllowed$;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
private cipherService: CipherService,
|
||||||
|
private vaultPopupItemsService: VaultPopupItemsService,
|
||||||
|
private passwordRepromptService: PasswordRepromptService,
|
||||||
|
private dialogService: DialogService,
|
||||||
|
private router: Router,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
get canEdit() {
|
||||||
|
return this.cipher.edit;
|
||||||
|
}
|
||||||
|
|
||||||
|
get isLogin() {
|
||||||
|
return this.cipher.type === CipherType.Login;
|
||||||
|
}
|
||||||
|
|
||||||
|
get favoriteText() {
|
||||||
|
return this.cipher.favorite ? "unfavorite" : "favorite";
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determines if the login cipher can be launched in a new browser tab.
|
||||||
|
*/
|
||||||
|
get canLaunch() {
|
||||||
|
return this.isLogin && this.cipher.login.canLaunch;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Launches the login cipher in a new browser tab.
|
||||||
|
*/
|
||||||
|
async launchCipher() {
|
||||||
|
if (!this.canLaunch) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await this.cipherService.updateLastLaunchedDate(this.cipher.id);
|
||||||
|
|
||||||
|
await BrowserApi.createNewTab(this.cipher.login.launchUri);
|
||||||
|
|
||||||
|
if (BrowserPopupUtils.inPopup(window)) {
|
||||||
|
BrowserApi.closePopup(window);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Toggles the favorite status of the cipher and updates it on the server.
|
||||||
|
*/
|
||||||
|
async toggleFavorite() {
|
||||||
|
this.cipher.favorite = !this.cipher.favorite;
|
||||||
|
const encryptedCipher = await this.cipherService.encrypt(this.cipher);
|
||||||
|
await this.cipherService.updateWithServer(encryptedCipher);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Navigate to the clone cipher page with the current cipher as the source.
|
||||||
|
* A password reprompt is attempted if the cipher requires it.
|
||||||
|
* A confirmation dialog is shown if the cipher has FIDO2 credentials.
|
||||||
|
*/
|
||||||
|
async clone() {
|
||||||
|
if (
|
||||||
|
this.cipher.reprompt === CipherRepromptType.Password &&
|
||||||
|
!(await this.passwordRepromptService.showPasswordPrompt())
|
||||||
|
) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.cipher.login?.hasFido2Credentials) {
|
||||||
|
const confirmed = await this.dialogService.openSimpleDialog({
|
||||||
|
title: { key: "passkeyNotCopied" },
|
||||||
|
content: { key: "passkeyNotCopiedAlert" },
|
||||||
|
type: "info",
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!confirmed) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
await this.router.navigate(["/clone-cipher"], {
|
||||||
|
queryParams: {
|
||||||
|
cloneMode: true,
|
||||||
|
cipherId: this.cipher.id,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,39 @@
|
|||||||
|
<form [formGroup]="filterForm" class="tw-flex tw-flex-wrap tw-gap-2 tw-mb-6 tw-mt-2">
|
||||||
|
<ng-container *ngIf="organizations$ | async as organizations">
|
||||||
|
<bit-chip-select
|
||||||
|
*ngIf="organizations.length"
|
||||||
|
formControlName="organization"
|
||||||
|
placeholderIcon="bwi-vault"
|
||||||
|
[placeholderText]="'vault' | i18n"
|
||||||
|
[options]="organizations"
|
||||||
|
>
|
||||||
|
</bit-chip-select>
|
||||||
|
</ng-container>
|
||||||
|
<ng-container *ngIf="collections$ | async as collections">
|
||||||
|
<bit-chip-select
|
||||||
|
*ngIf="collections.length"
|
||||||
|
formControlName="collection"
|
||||||
|
placeholderIcon="bwi-collection"
|
||||||
|
[placeholderText]="'collections' | i18n"
|
||||||
|
[options]="collections"
|
||||||
|
>
|
||||||
|
</bit-chip-select>
|
||||||
|
</ng-container>
|
||||||
|
<ng-container *ngIf="folders$ | async as folders">
|
||||||
|
<bit-chip-select
|
||||||
|
*ngIf="folders.length"
|
||||||
|
placeholderIcon="bwi-folder"
|
||||||
|
formControlName="folder"
|
||||||
|
[placeholderText]="'folder' | i18n"
|
||||||
|
[options]="folders"
|
||||||
|
>
|
||||||
|
</bit-chip-select>
|
||||||
|
</ng-container>
|
||||||
|
<bit-chip-select
|
||||||
|
formControlName="cipherType"
|
||||||
|
placeholderIcon="bwi-list"
|
||||||
|
[placeholderText]="'types' | i18n"
|
||||||
|
[options]="cipherTypes"
|
||||||
|
>
|
||||||
|
</bit-chip-select>
|
||||||
|
</form>
|
||||||
@@ -0,0 +1,28 @@
|
|||||||
|
import { CommonModule } from "@angular/common";
|
||||||
|
import { Component, OnDestroy } from "@angular/core";
|
||||||
|
import { ReactiveFormsModule } from "@angular/forms";
|
||||||
|
|
||||||
|
import { JslibModule } from "@bitwarden/angular/jslib.module";
|
||||||
|
import { ChipSelectComponent } from "@bitwarden/components";
|
||||||
|
|
||||||
|
import { VaultPopupListFiltersService } from "../../../services/vault-popup-list-filters.service";
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
standalone: true,
|
||||||
|
selector: "app-vault-list-filters",
|
||||||
|
templateUrl: "./vault-list-filters.component.html",
|
||||||
|
imports: [CommonModule, JslibModule, ChipSelectComponent, ReactiveFormsModule],
|
||||||
|
})
|
||||||
|
export class VaultListFiltersComponent implements OnDestroy {
|
||||||
|
protected filterForm = this.vaultPopupListFiltersService.filterForm;
|
||||||
|
protected organizations$ = this.vaultPopupListFiltersService.organizations$;
|
||||||
|
protected collections$ = this.vaultPopupListFiltersService.collections$;
|
||||||
|
protected folders$ = this.vaultPopupListFiltersService.folders$;
|
||||||
|
protected cipherTypes = this.vaultPopupListFiltersService.cipherTypes;
|
||||||
|
|
||||||
|
constructor(private vaultPopupListFiltersService: VaultPopupListFiltersService) {}
|
||||||
|
|
||||||
|
ngOnDestroy(): void {
|
||||||
|
this.vaultPopupListFiltersService.resetFilterForm();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -13,31 +13,31 @@
|
|||||||
</popup-section-header>
|
</popup-section-header>
|
||||||
<bit-item-group>
|
<bit-item-group>
|
||||||
<bit-item *ngFor="let cipher of ciphers">
|
<bit-item *ngFor="let cipher of ciphers">
|
||||||
<a bit-item-content [routerLink]="['/view-cipher']" [queryParams]="{ cipherId: cipher.id }">
|
<a
|
||||||
|
bit-item-content
|
||||||
|
[routerLink]="['/view-cipher']"
|
||||||
|
[queryParams]="{ cipherId: cipher.id }"
|
||||||
|
[appA11yTitle]="'viewItemTitle' | i18n: cipher.name"
|
||||||
|
>
|
||||||
<app-vault-icon slot="start" [cipher]="cipher"></app-vault-icon>
|
<app-vault-icon slot="start" [cipher]="cipher"></app-vault-icon>
|
||||||
{{ cipher.name }}
|
{{ cipher.name }}
|
||||||
|
<i
|
||||||
|
class="bwi bwi-sm"
|
||||||
|
*ngIf="cipher.organizationId"
|
||||||
|
[ngClass]="cipher.orgIcon"
|
||||||
|
[appA11yTitle]="orgIconTooltip(cipher)"
|
||||||
|
></i>
|
||||||
<span slot="secondary">{{ cipher.subTitle }}</span>
|
<span slot="secondary">{{ cipher.subTitle }}</span>
|
||||||
</a>
|
</a>
|
||||||
<ng-container slot="end">
|
<ng-container slot="end">
|
||||||
<bit-item-action *ngIf="showAutoFill">
|
<bit-item-action *ngIf="showAutofillButton">
|
||||||
<button type="button" bitBadge variant="primary">{{ "autoFill" | i18n }}</button>
|
<button type="button" bitBadge variant="primary">{{ "autoFill" | i18n }}</button>
|
||||||
</bit-item-action>
|
</bit-item-action>
|
||||||
<bit-item-action>
|
<app-item-copy-actions [cipher]="cipher"></app-item-copy-actions>
|
||||||
<button
|
<app-item-more-options
|
||||||
type="button"
|
[cipher]="cipher"
|
||||||
bitIconButton="bwi-clone"
|
[hideLoginOptions]="showAutofillButton"
|
||||||
size="small"
|
></app-item-more-options>
|
||||||
[attr.aria-label]="'copyInfo' | i18n: cipher.name"
|
|
||||||
></button>
|
|
||||||
</bit-item-action>
|
|
||||||
<bit-item-action>
|
|
||||||
<button
|
|
||||||
type="button"
|
|
||||||
bitIconButton="bwi-ellipsis-v"
|
|
||||||
size="small"
|
|
||||||
[attr.aria-label]="'moreOptions' | i18n: cipher.name"
|
|
||||||
></button>
|
|
||||||
</bit-item-action>
|
|
||||||
</ng-container>
|
</ng-container>
|
||||||
</bit-item>
|
</bit-item>
|
||||||
</bit-item-group>
|
</bit-item-group>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { booleanAttribute, Component, EventEmitter, Input, Output } from "@angul
|
|||||||
import { RouterLink } from "@angular/router";
|
import { RouterLink } from "@angular/router";
|
||||||
|
|
||||||
import { JslibModule } from "@bitwarden/angular/jslib.module";
|
import { JslibModule } from "@bitwarden/angular/jslib.module";
|
||||||
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
import { I18nService } from "@bitwarden/common/platform/abstractions/i18n.service";
|
||||||
import {
|
import {
|
||||||
BadgeModule,
|
BadgeModule,
|
||||||
ButtonModule,
|
ButtonModule,
|
||||||
@@ -14,6 +14,9 @@ import {
|
|||||||
} from "@bitwarden/components";
|
} from "@bitwarden/components";
|
||||||
|
|
||||||
import { PopupSectionHeaderComponent } from "../../../../../platform/popup/popup-section-header/popup-section-header.component";
|
import { PopupSectionHeaderComponent } from "../../../../../platform/popup/popup-section-header/popup-section-header.component";
|
||||||
|
import { PopupCipherView } from "../../../views/popup-cipher.view";
|
||||||
|
import { ItemCopyActionsComponent } from "../item-copy-action/item-copy-actions.component";
|
||||||
|
import { ItemMoreOptionsComponent } from "../item-more-options/item-more-options.component";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
imports: [
|
imports: [
|
||||||
@@ -27,6 +30,8 @@ import { PopupSectionHeaderComponent } from "../../../../../platform/popup/popup
|
|||||||
JslibModule,
|
JslibModule,
|
||||||
PopupSectionHeaderComponent,
|
PopupSectionHeaderComponent,
|
||||||
RouterLink,
|
RouterLink,
|
||||||
|
ItemCopyActionsComponent,
|
||||||
|
ItemMoreOptionsComponent,
|
||||||
],
|
],
|
||||||
selector: "app-vault-list-items-container",
|
selector: "app-vault-list-items-container",
|
||||||
templateUrl: "vault-list-items-container.component.html",
|
templateUrl: "vault-list-items-container.component.html",
|
||||||
@@ -37,7 +42,7 @@ export class VaultListItemsContainerComponent {
|
|||||||
* The list of ciphers to display.
|
* The list of ciphers to display.
|
||||||
*/
|
*/
|
||||||
@Input()
|
@Input()
|
||||||
ciphers: CipherView[];
|
ciphers: PopupCipherView[] = [];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Title for the vault list item section.
|
* Title for the vault list item section.
|
||||||
@@ -61,5 +66,19 @@ export class VaultListItemsContainerComponent {
|
|||||||
* Option to show the autofill button for each item.
|
* Option to show the autofill button for each item.
|
||||||
*/
|
*/
|
||||||
@Input({ transform: booleanAttribute })
|
@Input({ transform: booleanAttribute })
|
||||||
showAutoFill: boolean;
|
showAutofillButton: boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The tooltip text for the organization icon for ciphers that belong to an organization.
|
||||||
|
* @param cipher
|
||||||
|
*/
|
||||||
|
orgIconTooltip(cipher: PopupCipherView) {
|
||||||
|
if (cipher.collectionIds.length > 1) {
|
||||||
|
return this.i18nService.t("nCollections", cipher.collectionIds.length);
|
||||||
|
}
|
||||||
|
|
||||||
|
return cipher.collections[0]?.name;
|
||||||
|
}
|
||||||
|
|
||||||
|
constructor(private i18nService: I18nService) {}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,13 +22,15 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<ng-container *ngIf="!(showEmptyState$ | async)">
|
<ng-container *ngIf="!(showEmptyState$ | async)">
|
||||||
<!-- TODO: Filter/search Section in PM-6824 and PM-6826.-->
|
<div class="tw-fixed">
|
||||||
|
<app-vault-v2-search (searchTextChanged)="handleSearchTextChange($event)">
|
||||||
|
</app-vault-v2-search>
|
||||||
|
|
||||||
<app-vault-v2-search (searchTextChanged)="handleSearchTextChange($event)">
|
<app-vault-list-filters></app-vault-list-filters>
|
||||||
</app-vault-v2-search>
|
</div>
|
||||||
|
|
||||||
<div
|
<div
|
||||||
*ngIf="showNoResultsState$ | async"
|
*ngIf="(showNoResultsState$ | async) && !(showDeactivatedOrg$ | async)"
|
||||||
class="tw-flex tw-flex-col tw-h-full tw-justify-center"
|
class="tw-flex tw-flex-col tw-h-full tw-justify-center"
|
||||||
>
|
>
|
||||||
<bit-no-items>
|
<bit-no-items>
|
||||||
@@ -37,7 +39,17 @@
|
|||||||
</bit-no-items>
|
</bit-no-items>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<ng-container *ngIf="!(showNoResultsState$ | async)">
|
<div
|
||||||
|
*ngIf="showDeactivatedOrg$ | async"
|
||||||
|
class="tw-flex tw-flex-col tw-h-full tw-justify-center"
|
||||||
|
>
|
||||||
|
<bit-no-items [icon]="deactivatedIcon">
|
||||||
|
<ng-container slot="title">{{ "organizationIsDeactivated" | i18n }}</ng-container>
|
||||||
|
<ng-container slot="description">{{ "contactYourOrgAdmin" | i18n }}</ng-container>
|
||||||
|
</bit-no-items>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<ng-container *ngIf="!(showNoResultsState$ | async) && !(showDeactivatedOrg$ | async)">
|
||||||
<app-autofill-vault-list-items></app-autofill-vault-list-items>
|
<app-autofill-vault-list-items></app-autofill-vault-list-items>
|
||||||
<app-vault-list-items-container
|
<app-vault-list-items-container
|
||||||
[title]="'favorites' | i18n"
|
[title]="'favorites' | i18n"
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ import { PopupHeaderComponent } from "../../../../platform/popup/layout/popup-he
|
|||||||
import { PopupPageComponent } from "../../../../platform/popup/layout/popup-page.component";
|
import { PopupPageComponent } from "../../../../platform/popup/layout/popup-page.component";
|
||||||
import { VaultPopupItemsService } from "../../services/vault-popup-items.service";
|
import { VaultPopupItemsService } from "../../services/vault-popup-items.service";
|
||||||
import { AutofillVaultListItemsComponent, VaultListItemsContainerComponent } from "../vault-v2";
|
import { AutofillVaultListItemsComponent, VaultListItemsContainerComponent } from "../vault-v2";
|
||||||
|
import { VaultListFiltersComponent } from "../vault-v2/vault-list-filters/vault-list-filters.component";
|
||||||
import { VaultV2SearchComponent } from "../vault-v2/vault-search/vault-v2-search.component";
|
import { VaultV2SearchComponent } from "../vault-v2/vault-search/vault-v2-search.component";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
@@ -27,6 +28,7 @@ import { VaultV2SearchComponent } from "../vault-v2/vault-search/vault-v2-search
|
|||||||
CommonModule,
|
CommonModule,
|
||||||
AutofillVaultListItemsComponent,
|
AutofillVaultListItemsComponent,
|
||||||
VaultListItemsContainerComponent,
|
VaultListItemsContainerComponent,
|
||||||
|
VaultListFiltersComponent,
|
||||||
ButtonModule,
|
ButtonModule,
|
||||||
RouterLink,
|
RouterLink,
|
||||||
VaultV2SearchComponent,
|
VaultV2SearchComponent,
|
||||||
@@ -38,8 +40,10 @@ export class VaultV2Component implements OnInit, OnDestroy {
|
|||||||
|
|
||||||
protected showEmptyState$ = this.vaultPopupItemsService.emptyVault$;
|
protected showEmptyState$ = this.vaultPopupItemsService.emptyVault$;
|
||||||
protected showNoResultsState$ = this.vaultPopupItemsService.noFilteredResults$;
|
protected showNoResultsState$ = this.vaultPopupItemsService.noFilteredResults$;
|
||||||
|
protected showDeactivatedOrg$ = this.vaultPopupItemsService.showDeactivatedOrg$;
|
||||||
|
|
||||||
protected vaultIcon = Icons.Vault;
|
protected vaultIcon = Icons.Vault;
|
||||||
|
protected deactivatedIcon = Icons.DeactivatedOrg;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
private vaultPopupItemsService: VaultPopupItemsService,
|
private vaultPopupItemsService: VaultPopupItemsService,
|
||||||
|
|||||||
@@ -1,26 +1,40 @@
|
|||||||
|
import { TestBed } from "@angular/core/testing";
|
||||||
import { mock } from "jest-mock-extended";
|
import { mock } from "jest-mock-extended";
|
||||||
import { BehaviorSubject } from "rxjs";
|
import { BehaviorSubject } from "rxjs";
|
||||||
|
|
||||||
import { SearchService } from "@bitwarden/common/abstractions/search.service";
|
import { SearchService } from "@bitwarden/common/abstractions/search.service";
|
||||||
|
import { OrganizationService } from "@bitwarden/common/admin-console/abstractions/organization/organization.service.abstraction";
|
||||||
|
import { Organization } from "@bitwarden/common/admin-console/models/domain/organization";
|
||||||
|
import { ProductType } from "@bitwarden/common/enums";
|
||||||
import { CipherId } from "@bitwarden/common/types/guid";
|
import { CipherId } from "@bitwarden/common/types/guid";
|
||||||
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
||||||
|
import { CollectionService } from "@bitwarden/common/vault/abstractions/collection.service";
|
||||||
import { VaultSettingsService } from "@bitwarden/common/vault/abstractions/vault-settings/vault-settings.service";
|
import { VaultSettingsService } from "@bitwarden/common/vault/abstractions/vault-settings/vault-settings.service";
|
||||||
import { CipherType } from "@bitwarden/common/vault/enums";
|
import { CipherType } from "@bitwarden/common/vault/enums";
|
||||||
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
||||||
|
import { CollectionView } from "@bitwarden/common/vault/models/view/collection.view";
|
||||||
|
|
||||||
import { BrowserApi } from "../../../platform/browser/browser-api";
|
import { BrowserApi } from "../../../platform/browser/browser-api";
|
||||||
import BrowserPopupUtils from "../../../platform/popup/browser-popup-utils";
|
import BrowserPopupUtils from "../../../platform/popup/browser-popup-utils";
|
||||||
|
|
||||||
import { VaultPopupItemsService } from "./vault-popup-items.service";
|
import { VaultPopupItemsService } from "./vault-popup-items.service";
|
||||||
|
import { VaultPopupListFiltersService } from "./vault-popup-list-filters.service";
|
||||||
|
|
||||||
describe("VaultPopupItemsService", () => {
|
describe("VaultPopupItemsService", () => {
|
||||||
|
let testBed: TestBed;
|
||||||
let service: VaultPopupItemsService;
|
let service: VaultPopupItemsService;
|
||||||
let allCiphers: Record<CipherId, CipherView>;
|
let allCiphers: Record<CipherId, CipherView>;
|
||||||
let autoFillCiphers: CipherView[];
|
let autoFillCiphers: CipherView[];
|
||||||
|
|
||||||
|
let mockOrg: Organization;
|
||||||
|
let mockCollections: CollectionView[];
|
||||||
|
|
||||||
const cipherServiceMock = mock<CipherService>();
|
const cipherServiceMock = mock<CipherService>();
|
||||||
const vaultSettingsServiceMock = mock<VaultSettingsService>();
|
const vaultSettingsServiceMock = mock<VaultSettingsService>();
|
||||||
|
const organizationServiceMock = mock<OrganizationService>();
|
||||||
|
const vaultPopupListFiltersServiceMock = mock<VaultPopupListFiltersService>();
|
||||||
const searchService = mock<SearchService>();
|
const searchService = mock<SearchService>();
|
||||||
|
const collectionService = mock<CollectionService>();
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
allCiphers = cipherFactory(10);
|
allCiphers = cipherFactory(10);
|
||||||
@@ -35,31 +49,80 @@ describe("VaultPopupItemsService", () => {
|
|||||||
cipherList[2].favorite = true;
|
cipherList[2].favorite = true;
|
||||||
cipherList[3].favorite = true;
|
cipherList[3].favorite = true;
|
||||||
|
|
||||||
cipherServiceMock.cipherViews$ = new BehaviorSubject(allCiphers).asObservable();
|
cipherServiceMock.getAllDecrypted.mockResolvedValue(cipherList);
|
||||||
searchService.searchCiphers.mockImplementation(async () => cipherList);
|
cipherServiceMock.ciphers$ = new BehaviorSubject(null).asObservable();
|
||||||
cipherServiceMock.filterCiphersForUrl.mockImplementation(async () => autoFillCiphers);
|
searchService.searchCiphers.mockImplementation(async (_, __, ciphers) => ciphers);
|
||||||
vaultSettingsServiceMock.showCardsCurrentTab$ = new BehaviorSubject(false).asObservable();
|
cipherServiceMock.filterCiphersForUrl.mockImplementation(async (ciphers) =>
|
||||||
vaultSettingsServiceMock.showIdentitiesCurrentTab$ = new BehaviorSubject(false).asObservable();
|
ciphers.filter((c) => ["0", "1"].includes(c.id)),
|
||||||
|
);
|
||||||
|
vaultSettingsServiceMock.showCardsCurrentTab$ = new BehaviorSubject(false);
|
||||||
|
vaultSettingsServiceMock.showIdentitiesCurrentTab$ = new BehaviorSubject(false);
|
||||||
|
|
||||||
|
vaultPopupListFiltersServiceMock.filters$ = new BehaviorSubject({
|
||||||
|
organization: null,
|
||||||
|
collection: null,
|
||||||
|
cipherType: null,
|
||||||
|
folder: null,
|
||||||
|
});
|
||||||
|
// Return all ciphers, `filterFunction$` will be tested in `VaultPopupListFiltersService`
|
||||||
|
vaultPopupListFiltersServiceMock.filterFunction$ = new BehaviorSubject(
|
||||||
|
(ciphers: CipherView[]) => ciphers,
|
||||||
|
);
|
||||||
jest.spyOn(BrowserPopupUtils, "inPopout").mockReturnValue(false);
|
jest.spyOn(BrowserPopupUtils, "inPopout").mockReturnValue(false);
|
||||||
jest
|
jest
|
||||||
.spyOn(BrowserApi, "getTabFromCurrentWindow")
|
.spyOn(BrowserApi, "getTabFromCurrentWindow")
|
||||||
.mockResolvedValue({ url: "https://example.com" } as chrome.tabs.Tab);
|
.mockResolvedValue({ url: "https://example.com" } as chrome.tabs.Tab);
|
||||||
service = new VaultPopupItemsService(
|
|
||||||
cipherServiceMock,
|
mockOrg = {
|
||||||
vaultSettingsServiceMock,
|
id: "org1",
|
||||||
searchService,
|
name: "Organization 1",
|
||||||
);
|
planProductType: ProductType.Enterprise,
|
||||||
|
} as Organization;
|
||||||
|
|
||||||
|
mockCollections = [
|
||||||
|
{ id: "col1", name: "Collection 1" } as CollectionView,
|
||||||
|
{ id: "col2", name: "Collection 2" } as CollectionView,
|
||||||
|
];
|
||||||
|
|
||||||
|
organizationServiceMock.organizations$ = new BehaviorSubject([mockOrg]);
|
||||||
|
collectionService.decryptedCollections$ = new BehaviorSubject(mockCollections);
|
||||||
|
|
||||||
|
testBed = TestBed.configureTestingModule({
|
||||||
|
providers: [
|
||||||
|
{ provide: CipherService, useValue: cipherServiceMock },
|
||||||
|
{ provide: VaultSettingsService, useValue: vaultSettingsServiceMock },
|
||||||
|
{ provide: SearchService, useValue: searchService },
|
||||||
|
{ provide: OrganizationService, useValue: organizationServiceMock },
|
||||||
|
{ provide: VaultPopupListFiltersService, useValue: vaultPopupListFiltersServiceMock },
|
||||||
|
{ provide: CollectionService, useValue: collectionService },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
service = testBed.inject(VaultPopupItemsService);
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
jest.clearAllMocks();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should be created", () => {
|
it("should be created", () => {
|
||||||
service = new VaultPopupItemsService(
|
service = testBed.inject(VaultPopupItemsService);
|
||||||
cipherServiceMock,
|
|
||||||
vaultSettingsServiceMock,
|
|
||||||
searchService,
|
|
||||||
);
|
|
||||||
expect(service).toBeTruthy();
|
expect(service).toBeTruthy();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("should merge cipher views with collections and organization", (done) => {
|
||||||
|
const cipherList = Object.values(allCiphers);
|
||||||
|
cipherList[0].organizationId = "org1";
|
||||||
|
cipherList[0].collectionIds = ["col1", "col2"];
|
||||||
|
|
||||||
|
service.autoFillCiphers$.subscribe((ciphers) => {
|
||||||
|
expect(ciphers[0].organization).toEqual(mockOrg);
|
||||||
|
expect(ciphers[0].collections).toContain(mockCollections[0]);
|
||||||
|
expect(ciphers[0].collections).toContain(mockCollections[1]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe("autoFillCiphers$", () => {
|
describe("autoFillCiphers$", () => {
|
||||||
it("should return empty array if there is no current tab", (done) => {
|
it("should return empty array if there is no current tab", (done) => {
|
||||||
jest.spyOn(BrowserApi, "getTabFromCurrentWindow").mockResolvedValue(null);
|
jest.spyOn(BrowserApi, "getTabFromCurrentWindow").mockResolvedValue(null);
|
||||||
@@ -80,16 +143,10 @@ describe("VaultPopupItemsService", () => {
|
|||||||
it("should filter ciphers for the current tab and types", (done) => {
|
it("should filter ciphers for the current tab and types", (done) => {
|
||||||
const currentTab = { url: "https://example.com" } as chrome.tabs.Tab;
|
const currentTab = { url: "https://example.com" } as chrome.tabs.Tab;
|
||||||
|
|
||||||
vaultSettingsServiceMock.showCardsCurrentTab$ = new BehaviorSubject(true).asObservable();
|
(vaultSettingsServiceMock.showCardsCurrentTab$ as BehaviorSubject<boolean>).next(true);
|
||||||
vaultSettingsServiceMock.showIdentitiesCurrentTab$ = new BehaviorSubject(true).asObservable();
|
(vaultSettingsServiceMock.showIdentitiesCurrentTab$ as BehaviorSubject<boolean>).next(true);
|
||||||
jest.spyOn(BrowserApi, "getTabFromCurrentWindow").mockResolvedValue(currentTab);
|
jest.spyOn(BrowserApi, "getTabFromCurrentWindow").mockResolvedValue(currentTab);
|
||||||
|
|
||||||
service = new VaultPopupItemsService(
|
|
||||||
cipherServiceMock,
|
|
||||||
vaultSettingsServiceMock,
|
|
||||||
searchService,
|
|
||||||
);
|
|
||||||
|
|
||||||
service.autoFillCiphers$.subscribe((ciphers) => {
|
service.autoFillCiphers$.subscribe((ciphers) => {
|
||||||
expect(cipherServiceMock.filterCiphersForUrl.mock.calls.length).toBe(1);
|
expect(cipherServiceMock.filterCiphersForUrl.mock.calls.length).toBe(1);
|
||||||
expect(cipherServiceMock.filterCiphersForUrl).toHaveBeenCalledWith(
|
expect(cipherServiceMock.filterCiphersForUrl).toHaveBeenCalledWith(
|
||||||
@@ -114,12 +171,6 @@ describe("VaultPopupItemsService", () => {
|
|||||||
Object.values(allCiphers),
|
Object.values(allCiphers),
|
||||||
);
|
);
|
||||||
|
|
||||||
service = new VaultPopupItemsService(
|
|
||||||
cipherServiceMock,
|
|
||||||
vaultSettingsServiceMock,
|
|
||||||
searchService,
|
|
||||||
);
|
|
||||||
|
|
||||||
service.autoFillCiphers$.subscribe((ciphers) => {
|
service.autoFillCiphers$.subscribe((ciphers) => {
|
||||||
expect(ciphers.length).toBe(10);
|
expect(ciphers.length).toBe(10);
|
||||||
|
|
||||||
@@ -135,19 +186,18 @@ describe("VaultPopupItemsService", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("should filter autoFillCiphers$ down to search term", (done) => {
|
it("should filter autoFillCiphers$ down to search term", (done) => {
|
||||||
const cipherList = Object.values(allCiphers);
|
|
||||||
const searchText = "Login";
|
const searchText = "Login";
|
||||||
|
|
||||||
searchService.searchCiphers.mockImplementation(async () => {
|
searchService.searchCiphers.mockImplementation(async (q, _, ciphers) => {
|
||||||
return cipherList.filter((cipher) => {
|
return ciphers.filter((cipher) => {
|
||||||
return cipher.name.includes(searchText);
|
return cipher.name.includes(searchText);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
// there is only 1 Login returned for filteredCiphers. but two results expected because of other autofill types
|
// there is only 1 Login returned for filteredCiphers.
|
||||||
service.autoFillCiphers$.subscribe((ciphers) => {
|
service.autoFillCiphers$.subscribe((ciphers) => {
|
||||||
expect(ciphers[0].name.includes(searchText)).toBe(true);
|
expect(ciphers[0].name.includes(searchText)).toBe(true);
|
||||||
expect(ciphers.length).toBe(2);
|
expect(ciphers.length).toBe(1);
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -224,12 +274,7 @@ describe("VaultPopupItemsService", () => {
|
|||||||
|
|
||||||
describe("emptyVault$", () => {
|
describe("emptyVault$", () => {
|
||||||
it("should return true if there are no ciphers", (done) => {
|
it("should return true if there are no ciphers", (done) => {
|
||||||
cipherServiceMock.cipherViews$ = new BehaviorSubject({}).asObservable();
|
cipherServiceMock.getAllDecrypted.mockResolvedValue([]);
|
||||||
service = new VaultPopupItemsService(
|
|
||||||
cipherServiceMock,
|
|
||||||
vaultSettingsServiceMock,
|
|
||||||
searchService,
|
|
||||||
);
|
|
||||||
service.emptyVault$.subscribe((empty) => {
|
service.emptyVault$.subscribe((empty) => {
|
||||||
expect(empty).toBe(true);
|
expect(empty).toBe(true);
|
||||||
done();
|
done();
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
import { Injectable } from "@angular/core";
|
import { inject, Injectable, NgZone } from "@angular/core";
|
||||||
import {
|
import {
|
||||||
BehaviorSubject,
|
BehaviorSubject,
|
||||||
combineLatest,
|
combineLatest,
|
||||||
|
distinctUntilKeyChanged,
|
||||||
|
from,
|
||||||
map,
|
map,
|
||||||
Observable,
|
Observable,
|
||||||
of,
|
of,
|
||||||
@@ -12,13 +14,21 @@ import {
|
|||||||
} from "rxjs";
|
} from "rxjs";
|
||||||
|
|
||||||
import { SearchService } from "@bitwarden/common/abstractions/search.service";
|
import { SearchService } from "@bitwarden/common/abstractions/search.service";
|
||||||
|
import { OrganizationService } from "@bitwarden/common/admin-console/abstractions/organization/organization.service.abstraction";
|
||||||
|
import { Utils } from "@bitwarden/common/platform/misc/utils";
|
||||||
|
import { CollectionId, OrganizationId } from "@bitwarden/common/types/guid";
|
||||||
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
||||||
|
import { CollectionService } from "@bitwarden/common/vault/abstractions/collection.service";
|
||||||
import { VaultSettingsService } from "@bitwarden/common/vault/abstractions/vault-settings/vault-settings.service";
|
import { VaultSettingsService } from "@bitwarden/common/vault/abstractions/vault-settings/vault-settings.service";
|
||||||
import { CipherType } from "@bitwarden/common/vault/enums";
|
import { CipherType } from "@bitwarden/common/vault/enums";
|
||||||
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
||||||
|
|
||||||
import { BrowserApi } from "../../../platform/browser/browser-api";
|
import { BrowserApi } from "../../../platform/browser/browser-api";
|
||||||
|
import { runInsideAngular } from "../../../platform/browser/run-inside-angular.operator";
|
||||||
import BrowserPopupUtils from "../../../platform/popup/browser-popup-utils";
|
import BrowserPopupUtils from "../../../platform/popup/browser-popup-utils";
|
||||||
|
import { PopupCipherView } from "../views/popup-cipher.view";
|
||||||
|
|
||||||
|
import { MY_VAULT_ID, VaultPopupListFiltersService } from "./vault-popup-list-filters.service";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Service for managing the various item lists on the new Vault tab in the browser popup.
|
* Service for managing the various item lists on the new Vault tab in the browser popup.
|
||||||
@@ -67,14 +77,44 @@ export class VaultPopupItemsService {
|
|||||||
* Observable that contains the list of all decrypted ciphers.
|
* Observable that contains the list of all decrypted ciphers.
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
private _cipherList$: Observable<CipherView[]> = this.cipherService.cipherViews$.pipe(
|
private _cipherList$: Observable<PopupCipherView[]> = this.cipherService.ciphers$.pipe(
|
||||||
|
runInsideAngular(inject(NgZone)), // Workaround to ensure cipher$ state provider emissions are run inside Angular
|
||||||
|
switchMap(() => Utils.asyncToObservable(() => this.cipherService.getAllDecrypted())),
|
||||||
map((ciphers) => Object.values(ciphers)),
|
map((ciphers) => Object.values(ciphers)),
|
||||||
shareReplay({ refCount: false, bufferSize: 1 }),
|
switchMap((ciphers) =>
|
||||||
|
combineLatest([
|
||||||
|
this.organizationService.organizations$,
|
||||||
|
this.collectionService.decryptedCollections$,
|
||||||
|
]).pipe(
|
||||||
|
map(([organizations, collections]) => {
|
||||||
|
const orgMap = Object.fromEntries(organizations.map((org) => [org.id, org]));
|
||||||
|
const collectionMap = Object.fromEntries(collections.map((col) => [col.id, col]));
|
||||||
|
return ciphers.map(
|
||||||
|
(cipher) =>
|
||||||
|
new PopupCipherView(
|
||||||
|
cipher,
|
||||||
|
cipher.collectionIds?.map((colId) => collectionMap[colId as CollectionId]),
|
||||||
|
orgMap[cipher.organizationId as OrganizationId],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
shareReplay({ refCount: true, bufferSize: 1 }),
|
||||||
);
|
);
|
||||||
|
|
||||||
private _filteredCipherList$ = combineLatest([this._cipherList$, this.searchText$]).pipe(
|
private _filteredCipherList$: Observable<PopupCipherView[]> = combineLatest([
|
||||||
switchMap(([ciphers, searchText]) =>
|
this._cipherList$,
|
||||||
this.searchService.searchCiphers(searchText, null, ciphers),
|
this.searchText$,
|
||||||
|
this.vaultPopupListFiltersService.filterFunction$,
|
||||||
|
]).pipe(
|
||||||
|
map(([ciphers, searchText, filterFunction]): [CipherView[], string] => [
|
||||||
|
filterFunction(ciphers),
|
||||||
|
searchText,
|
||||||
|
]),
|
||||||
|
switchMap(
|
||||||
|
([ciphers, searchText]) =>
|
||||||
|
this.searchService.searchCiphers(searchText, null, ciphers) as Promise<PopupCipherView[]>,
|
||||||
),
|
),
|
||||||
shareReplay({ refCount: true, bufferSize: 1 }),
|
shareReplay({ refCount: true, bufferSize: 1 }),
|
||||||
);
|
);
|
||||||
@@ -85,7 +125,7 @@ export class VaultPopupItemsService {
|
|||||||
*
|
*
|
||||||
* See {@link refreshCurrentTab} to trigger re-evaluation of the current tab.
|
* See {@link refreshCurrentTab} to trigger re-evaluation of the current tab.
|
||||||
*/
|
*/
|
||||||
autoFillCiphers$: Observable<CipherView[]> = combineLatest([
|
autoFillCiphers$: Observable<PopupCipherView[]> = combineLatest([
|
||||||
this._filteredCipherList$,
|
this._filteredCipherList$,
|
||||||
this._otherAutoFillTypes$,
|
this._otherAutoFillTypes$,
|
||||||
this._currentAutofillTab$,
|
this._currentAutofillTab$,
|
||||||
@@ -104,7 +144,7 @@ export class VaultPopupItemsService {
|
|||||||
* List of favorite ciphers that are not currently suggested for autofill.
|
* List of favorite ciphers that are not currently suggested for autofill.
|
||||||
* Ciphers are sorted by last used date, then by name.
|
* Ciphers are sorted by last used date, then by name.
|
||||||
*/
|
*/
|
||||||
favoriteCiphers$: Observable<CipherView[]> = combineLatest([
|
favoriteCiphers$: Observable<PopupCipherView[]> = combineLatest([
|
||||||
this.autoFillCiphers$,
|
this.autoFillCiphers$,
|
||||||
this._filteredCipherList$,
|
this._filteredCipherList$,
|
||||||
]).pipe(
|
]).pipe(
|
||||||
@@ -121,7 +161,7 @@ export class VaultPopupItemsService {
|
|||||||
* List of all remaining ciphers that are not currently suggested for autofill or marked as favorite.
|
* List of all remaining ciphers that are not currently suggested for autofill or marked as favorite.
|
||||||
* Ciphers are sorted by name.
|
* Ciphers are sorted by name.
|
||||||
*/
|
*/
|
||||||
remainingCiphers$: Observable<CipherView[]> = combineLatest([
|
remainingCiphers$: Observable<PopupCipherView[]> = combineLatest([
|
||||||
this.autoFillCiphers$,
|
this.autoFillCiphers$,
|
||||||
this.favoriteCiphers$,
|
this.favoriteCiphers$,
|
||||||
this._filteredCipherList$,
|
this._filteredCipherList$,
|
||||||
@@ -137,10 +177,19 @@ export class VaultPopupItemsService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Observable that indicates whether a filter is currently applied to the ciphers.
|
* Observable that indicates whether a filter is currently applied to the ciphers.
|
||||||
* @todo Implement filter/search functionality in PM-6824 and PM-6826.
|
|
||||||
*/
|
*/
|
||||||
hasFilterApplied$: Observable<boolean> = this.searchText$.pipe(
|
hasFilterApplied$ = combineLatest([
|
||||||
switchMap((text) => this.searchService.isSearchable(text)),
|
this.searchText$,
|
||||||
|
this.vaultPopupListFiltersService.filters$,
|
||||||
|
]).pipe(
|
||||||
|
switchMap(([searchText, filters]) => {
|
||||||
|
return from(this.searchService.isSearchable(searchText)).pipe(
|
||||||
|
map(
|
||||||
|
(isSearchable) =>
|
||||||
|
isSearchable || Object.values(filters).some((filter) => filter !== null),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}),
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -156,16 +205,33 @@ export class VaultPopupItemsService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Observable that indicates whether there are no ciphers to show with the current filter.
|
* Observable that indicates whether there are no ciphers to show with the current filter.
|
||||||
* @todo Implement filter/search functionality in PM-6824 and PM-6826.
|
|
||||||
*/
|
*/
|
||||||
noFilteredResults$: Observable<boolean> = this._filteredCipherList$.pipe(
|
noFilteredResults$: Observable<boolean> = this._filteredCipherList$.pipe(
|
||||||
map((ciphers) => !ciphers.length),
|
map((ciphers) => !ciphers.length),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/** Observable that indicates when the user should see the deactivated org state */
|
||||||
|
showDeactivatedOrg$: Observable<boolean> = combineLatest([
|
||||||
|
this.vaultPopupListFiltersService.filters$.pipe(distinctUntilKeyChanged("organization")),
|
||||||
|
this.organizationService.organizations$,
|
||||||
|
]).pipe(
|
||||||
|
map(([filters, orgs]) => {
|
||||||
|
if (!filters.organization || filters.organization.id === MY_VAULT_ID) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
const org = orgs.find((o) => o.id === filters.organization.id);
|
||||||
|
return org ? !org.enabled : false;
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
private cipherService: CipherService,
|
private cipherService: CipherService,
|
||||||
private vaultSettingsService: VaultSettingsService,
|
private vaultSettingsService: VaultSettingsService,
|
||||||
|
private vaultPopupListFiltersService: VaultPopupListFiltersService,
|
||||||
|
private organizationService: OrganizationService,
|
||||||
private searchService: SearchService,
|
private searchService: SearchService,
|
||||||
|
private collectionService: CollectionService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -0,0 +1,321 @@
|
|||||||
|
import { TestBed } from "@angular/core/testing";
|
||||||
|
import { FormBuilder } from "@angular/forms";
|
||||||
|
import { BehaviorSubject, skipWhile } from "rxjs";
|
||||||
|
|
||||||
|
import { OrganizationService } from "@bitwarden/common/admin-console/abstractions/organization/organization.service.abstraction";
|
||||||
|
import { Organization } from "@bitwarden/common/admin-console/models/domain/organization";
|
||||||
|
import { I18nService } from "@bitwarden/common/platform/abstractions/i18n.service";
|
||||||
|
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
||||||
|
import { CollectionService } from "@bitwarden/common/vault/abstractions/collection.service";
|
||||||
|
import { FolderService } from "@bitwarden/common/vault/abstractions/folder/folder.service.abstraction";
|
||||||
|
import { CipherType } from "@bitwarden/common/vault/enums";
|
||||||
|
import { Collection } from "@bitwarden/common/vault/models/domain/collection";
|
||||||
|
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
||||||
|
import { CollectionView } from "@bitwarden/common/vault/models/view/collection.view";
|
||||||
|
import { FolderView } from "@bitwarden/common/vault/models/view/folder.view";
|
||||||
|
|
||||||
|
import { MY_VAULT_ID, VaultPopupListFiltersService } from "./vault-popup-list-filters.service";
|
||||||
|
|
||||||
|
describe("VaultPopupListFiltersService", () => {
|
||||||
|
let service: VaultPopupListFiltersService;
|
||||||
|
const memberOrganizations$ = new BehaviorSubject<{ name: string; id: string }[]>([]);
|
||||||
|
const folderViews$ = new BehaviorSubject([]);
|
||||||
|
const cipherViews$ = new BehaviorSubject({});
|
||||||
|
const decryptedCollections$ = new BehaviorSubject<CollectionView[]>([]);
|
||||||
|
|
||||||
|
const collectionService = {
|
||||||
|
decryptedCollections$,
|
||||||
|
getAllNested: () => Promise.resolve([]),
|
||||||
|
} as unknown as CollectionService;
|
||||||
|
|
||||||
|
const folderService = {
|
||||||
|
folderViews$,
|
||||||
|
} as unknown as FolderService;
|
||||||
|
|
||||||
|
const cipherService = {
|
||||||
|
cipherViews$,
|
||||||
|
} as unknown as CipherService;
|
||||||
|
|
||||||
|
const organizationService = {
|
||||||
|
memberOrganizations$,
|
||||||
|
} as unknown as OrganizationService;
|
||||||
|
|
||||||
|
const i18nService = {
|
||||||
|
t: (key: string) => key,
|
||||||
|
} as I18nService;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
memberOrganizations$.next([]);
|
||||||
|
decryptedCollections$.next([]);
|
||||||
|
|
||||||
|
collectionService.getAllNested = () => Promise.resolve([]);
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
providers: [
|
||||||
|
{
|
||||||
|
provide: FolderService,
|
||||||
|
useValue: folderService,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
provide: CipherService,
|
||||||
|
useValue: cipherService,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
provide: OrganizationService,
|
||||||
|
useValue: organizationService,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
provide: I18nService,
|
||||||
|
useValue: i18nService,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
provide: CollectionService,
|
||||||
|
useValue: collectionService,
|
||||||
|
},
|
||||||
|
{ provide: FormBuilder, useClass: FormBuilder },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
service = TestBed.inject(VaultPopupListFiltersService);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("cipherTypes", () => {
|
||||||
|
it("returns all cipher types", () => {
|
||||||
|
expect(service.cipherTypes.map((c) => c.value)).toEqual([
|
||||||
|
CipherType.Login,
|
||||||
|
CipherType.Card,
|
||||||
|
CipherType.Identity,
|
||||||
|
CipherType.SecureNote,
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("organizations$", () => {
|
||||||
|
it('does not add "myVault" to the list of organizations when there are no organizations', (done) => {
|
||||||
|
memberOrganizations$.next([]);
|
||||||
|
|
||||||
|
service.organizations$.subscribe((organizations) => {
|
||||||
|
expect(organizations.map((o) => o.label)).toEqual([]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('adds "myVault" to the list of organizations when there are other organizations', (done) => {
|
||||||
|
memberOrganizations$.next([{ name: "bobby's org", id: "1234-3323-23223" }]);
|
||||||
|
|
||||||
|
service.organizations$.subscribe((organizations) => {
|
||||||
|
expect(organizations.map((o) => o.label)).toEqual(["myVault", "bobby's org"]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("sorts organizations by name", (done) => {
|
||||||
|
memberOrganizations$.next([
|
||||||
|
{ name: "bobby's org", id: "1234-3323-23223" },
|
||||||
|
{ name: "alice's org", id: "2223-4343-99888" },
|
||||||
|
]);
|
||||||
|
|
||||||
|
service.organizations$.subscribe((organizations) => {
|
||||||
|
expect(organizations.map((o) => o.label)).toEqual([
|
||||||
|
"myVault",
|
||||||
|
"alice's org",
|
||||||
|
"bobby's org",
|
||||||
|
]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("collections$", () => {
|
||||||
|
const testCollection = {
|
||||||
|
id: "14cbf8e9-7a2a-4105-9bf6-b15c01203cef",
|
||||||
|
name: "Test collection",
|
||||||
|
organizationId: "3f860945-b237-40bc-a51e-b15c01203ccf",
|
||||||
|
} as CollectionView;
|
||||||
|
|
||||||
|
const testCollection2 = {
|
||||||
|
id: "b15c0120-7a2a-4105-9bf6-b15c01203ceg",
|
||||||
|
name: "Test collection 2",
|
||||||
|
organizationId: "1203ccf-2432-123-acdd-b15c01203ccf",
|
||||||
|
} as CollectionView;
|
||||||
|
|
||||||
|
const testCollections = [testCollection, testCollection2];
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
decryptedCollections$.next(testCollections);
|
||||||
|
|
||||||
|
collectionService.getAllNested = () =>
|
||||||
|
Promise.resolve(
|
||||||
|
testCollections.map((c) => ({
|
||||||
|
children: [],
|
||||||
|
node: c,
|
||||||
|
parent: null,
|
||||||
|
})),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("returns all collections", (done) => {
|
||||||
|
service.collections$.subscribe((collections) => {
|
||||||
|
expect(collections.map((c) => c.label)).toEqual(["Test collection", "Test collection 2"]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("filters out collections that do not belong to an organization", () => {
|
||||||
|
service.filterForm.patchValue({
|
||||||
|
organization: { id: testCollection2.organizationId } as Organization,
|
||||||
|
});
|
||||||
|
|
||||||
|
service.collections$.subscribe((collections) => {
|
||||||
|
expect(collections.map((c) => c.label)).toEqual(["Test collection 2"]);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("sets collection icon", (done) => {
|
||||||
|
service.collections$.subscribe((collections) => {
|
||||||
|
expect(collections.every(({ icon }) => icon === "bwi-collection")).toBeTruthy();
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("folders$", () => {
|
||||||
|
it('returns no folders when "No Folder" is the only option', (done) => {
|
||||||
|
folderViews$.next([{ id: null, name: "No Folder" }]);
|
||||||
|
|
||||||
|
service.folders$.subscribe((folders) => {
|
||||||
|
expect(folders).toEqual([]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('moves "No Folder" to the end of the list', (done) => {
|
||||||
|
folderViews$.next([
|
||||||
|
{ id: null, name: "No Folder" },
|
||||||
|
{ id: "2345", name: "Folder 2" },
|
||||||
|
{ id: "1234", name: "Folder 1" },
|
||||||
|
]);
|
||||||
|
|
||||||
|
service.folders$.subscribe((folders) => {
|
||||||
|
expect(folders.map((f) => f.label)).toEqual(["Folder 1", "Folder 2", "itemsWithNoFolder"]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("returns all folders when MyVault is selected", (done) => {
|
||||||
|
service.filterForm.patchValue({
|
||||||
|
organization: { id: MY_VAULT_ID } as Organization,
|
||||||
|
});
|
||||||
|
|
||||||
|
folderViews$.next([
|
||||||
|
{ id: "1234", name: "Folder 1" },
|
||||||
|
{ id: "2345", name: "Folder 2" },
|
||||||
|
]);
|
||||||
|
|
||||||
|
service.folders$.subscribe((folders) => {
|
||||||
|
expect(folders.map((f) => f.label)).toEqual(["Folder 1", "Folder 2"]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("sets folder icon", (done) => {
|
||||||
|
service.filterForm.patchValue({
|
||||||
|
organization: { id: MY_VAULT_ID } as Organization,
|
||||||
|
});
|
||||||
|
|
||||||
|
folderViews$.next([
|
||||||
|
{ id: "1234", name: "Folder 1" },
|
||||||
|
{ id: "2345", name: "Folder 2" },
|
||||||
|
]);
|
||||||
|
|
||||||
|
service.folders$.subscribe((folders) => {
|
||||||
|
expect(folders.every(({ icon }) => icon === "bwi-folder")).toBeTruthy();
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("returns folders that have ciphers within the selected organization", (done) => {
|
||||||
|
service.folders$.pipe(skipWhile((folders) => folders.length === 2)).subscribe((folders) => {
|
||||||
|
expect(folders.map((f) => f.label)).toEqual(["Folder 1"]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
service.filterForm.patchValue({
|
||||||
|
organization: { id: "1234" } as Organization,
|
||||||
|
});
|
||||||
|
|
||||||
|
folderViews$.next([
|
||||||
|
{ id: "1234", name: "Folder 1" },
|
||||||
|
{ id: "2345", name: "Folder 2" },
|
||||||
|
]);
|
||||||
|
|
||||||
|
cipherViews$.next({
|
||||||
|
"1": { folderId: "1234", organizationId: "1234" },
|
||||||
|
"2": { folderId: "2345", organizationId: "56789" },
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("filterFunction$", () => {
|
||||||
|
const ciphers = [
|
||||||
|
{ type: CipherType.Login, collectionIds: [], organizationId: null },
|
||||||
|
{ type: CipherType.Card, collectionIds: ["1234"], organizationId: "8978" },
|
||||||
|
{ type: CipherType.Identity, collectionIds: [], folderId: "5432", organizationId: null },
|
||||||
|
{ type: CipherType.SecureNote, collectionIds: [], organizationId: null },
|
||||||
|
] as CipherView[];
|
||||||
|
|
||||||
|
it("filters by cipherType", (done) => {
|
||||||
|
service.filterFunction$.subscribe((filterFunction) => {
|
||||||
|
expect(filterFunction(ciphers)).toEqual([ciphers[0]]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
service.filterForm.patchValue({ cipherType: CipherType.Login });
|
||||||
|
});
|
||||||
|
|
||||||
|
it("filters by collection", (done) => {
|
||||||
|
const collection = { id: "1234" } as Collection;
|
||||||
|
|
||||||
|
service.filterFunction$.subscribe((filterFunction) => {
|
||||||
|
expect(filterFunction(ciphers)).toEqual([ciphers[1]]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
service.filterForm.patchValue({ collection });
|
||||||
|
});
|
||||||
|
|
||||||
|
it("filters by folder", (done) => {
|
||||||
|
const folder = { id: "5432" } as FolderView;
|
||||||
|
|
||||||
|
service.filterFunction$.subscribe((filterFunction) => {
|
||||||
|
expect(filterFunction(ciphers)).toEqual([ciphers[2]]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
service.filterForm.patchValue({ folder });
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("organizationId", () => {
|
||||||
|
it("filters out ciphers that belong to an organization when MyVault is selected", (done) => {
|
||||||
|
const organization = { id: MY_VAULT_ID } as Organization;
|
||||||
|
|
||||||
|
service.filterFunction$.subscribe((filterFunction) => {
|
||||||
|
expect(filterFunction(ciphers)).toEqual([ciphers[0], ciphers[2], ciphers[3]]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
service.filterForm.patchValue({ organization });
|
||||||
|
});
|
||||||
|
|
||||||
|
it("filters out ciphers that do not belong to the selected organization", (done) => {
|
||||||
|
const organization = { id: "8978" } as Organization;
|
||||||
|
|
||||||
|
service.filterFunction$.subscribe((filterFunction) => {
|
||||||
|
expect(filterFunction(ciphers)).toEqual([ciphers[1]]);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
service.filterForm.patchValue({ organization });
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -0,0 +1,376 @@
|
|||||||
|
import { Injectable } from "@angular/core";
|
||||||
|
import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
|
||||||
|
import { FormBuilder } from "@angular/forms";
|
||||||
|
import {
|
||||||
|
Observable,
|
||||||
|
combineLatest,
|
||||||
|
distinctUntilChanged,
|
||||||
|
map,
|
||||||
|
startWith,
|
||||||
|
switchMap,
|
||||||
|
tap,
|
||||||
|
} from "rxjs";
|
||||||
|
|
||||||
|
import { DynamicTreeNode } from "@bitwarden/angular/vault/vault-filter/models/dynamic-tree-node.model";
|
||||||
|
import { OrganizationService } from "@bitwarden/common/admin-console/abstractions/organization/organization.service.abstraction";
|
||||||
|
import { Organization } from "@bitwarden/common/admin-console/models/domain/organization";
|
||||||
|
import { ProductType } from "@bitwarden/common/enums";
|
||||||
|
import { I18nService } from "@bitwarden/common/platform/abstractions/i18n.service";
|
||||||
|
import { Utils } from "@bitwarden/common/platform/misc/utils";
|
||||||
|
import { CipherService } from "@bitwarden/common/vault/abstractions/cipher.service";
|
||||||
|
import { CollectionService } from "@bitwarden/common/vault/abstractions/collection.service";
|
||||||
|
import { FolderService } from "@bitwarden/common/vault/abstractions/folder/folder.service.abstraction";
|
||||||
|
import { CipherType } from "@bitwarden/common/vault/enums";
|
||||||
|
import { Collection } from "@bitwarden/common/vault/models/domain/collection";
|
||||||
|
import { ITreeNodeObject, TreeNode } from "@bitwarden/common/vault/models/domain/tree-node";
|
||||||
|
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
||||||
|
import { CollectionView } from "@bitwarden/common/vault/models/view/collection.view";
|
||||||
|
import { FolderView } from "@bitwarden/common/vault/models/view/folder.view";
|
||||||
|
import { ServiceUtils } from "@bitwarden/common/vault/service-utils";
|
||||||
|
import { ChipSelectOption } from "@bitwarden/components";
|
||||||
|
|
||||||
|
/** All available cipher filters */
|
||||||
|
export type PopupListFilter = {
|
||||||
|
organization: Organization | null;
|
||||||
|
collection: Collection | null;
|
||||||
|
folder: FolderView | null;
|
||||||
|
cipherType: CipherType | null;
|
||||||
|
};
|
||||||
|
|
||||||
|
/** Delimiter that denotes a level of nesting */
|
||||||
|
const NESTING_DELIMITER = "/";
|
||||||
|
|
||||||
|
/** Id assigned to the "My vault" organization */
|
||||||
|
export const MY_VAULT_ID = "MyVault";
|
||||||
|
|
||||||
|
const INITIAL_FILTERS: PopupListFilter = {
|
||||||
|
organization: null,
|
||||||
|
collection: null,
|
||||||
|
folder: null,
|
||||||
|
cipherType: null,
|
||||||
|
};
|
||||||
|
|
||||||
|
@Injectable({
|
||||||
|
providedIn: "root",
|
||||||
|
})
|
||||||
|
export class VaultPopupListFiltersService {
|
||||||
|
/**
|
||||||
|
* UI form for all filters
|
||||||
|
*/
|
||||||
|
filterForm = this.formBuilder.group<PopupListFilter>(INITIAL_FILTERS);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Observable for `filterForm` value
|
||||||
|
*/
|
||||||
|
filters$ = this.filterForm.valueChanges.pipe(
|
||||||
|
startWith(INITIAL_FILTERS),
|
||||||
|
) as Observable<PopupListFilter>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Static list of ciphers views used in synchronous context
|
||||||
|
*/
|
||||||
|
private cipherViews: CipherView[] = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Observable of cipher views
|
||||||
|
*/
|
||||||
|
private cipherViews$: Observable<CipherView[]> = this.cipherService.cipherViews$.pipe(
|
||||||
|
tap((cipherViews) => {
|
||||||
|
this.cipherViews = Object.values(cipherViews);
|
||||||
|
}),
|
||||||
|
map((ciphers) => Object.values(ciphers)),
|
||||||
|
);
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
private folderService: FolderService,
|
||||||
|
private cipherService: CipherService,
|
||||||
|
private organizationService: OrganizationService,
|
||||||
|
private i18nService: I18nService,
|
||||||
|
private collectionService: CollectionService,
|
||||||
|
private formBuilder: FormBuilder,
|
||||||
|
) {
|
||||||
|
this.filterForm.controls.organization.valueChanges
|
||||||
|
.pipe(takeUntilDestroyed())
|
||||||
|
.subscribe(this.validateOrganizationChange.bind(this));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Observable whose value is a function that filters an array of `CipherView` objects based on the current filters
|
||||||
|
*/
|
||||||
|
filterFunction$: Observable<(ciphers: CipherView[]) => CipherView[]> = this.filters$.pipe(
|
||||||
|
map(
|
||||||
|
(filters) => (ciphers: CipherView[]) =>
|
||||||
|
ciphers.filter((cipher) => {
|
||||||
|
if (filters.cipherType !== null && cipher.type !== filters.cipherType) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
filters.collection !== null &&
|
||||||
|
!cipher.collectionIds.includes(filters.collection.id)
|
||||||
|
) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (filters.folder !== null && cipher.folderId !== filters.folder.id) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
const isMyVault = filters.organization?.id === MY_VAULT_ID;
|
||||||
|
|
||||||
|
if (isMyVault) {
|
||||||
|
if (cipher.organizationId !== null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else if (filters.organization !== null) {
|
||||||
|
if (cipher.organizationId !== filters.organization.id) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* All available cipher types
|
||||||
|
*/
|
||||||
|
readonly cipherTypes: ChipSelectOption<CipherType>[] = [
|
||||||
|
{
|
||||||
|
value: CipherType.Login,
|
||||||
|
label: this.i18nService.t("logins"),
|
||||||
|
icon: "bwi-globe",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: CipherType.Card,
|
||||||
|
label: this.i18nService.t("cards"),
|
||||||
|
icon: "bwi-credit-card",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: CipherType.Identity,
|
||||||
|
label: this.i18nService.t("identities"),
|
||||||
|
icon: "bwi-id-card",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: CipherType.SecureNote,
|
||||||
|
label: this.i18nService.t("notes"),
|
||||||
|
icon: "bwi-sticky-note",
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
/** Resets `filterForm` to the original state */
|
||||||
|
resetFilterForm(): void {
|
||||||
|
this.filterForm.reset(INITIAL_FILTERS);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Organization array structured to be directly passed to `ChipSelectComponent`
|
||||||
|
*/
|
||||||
|
organizations$: Observable<ChipSelectOption<Organization>[]> =
|
||||||
|
this.organizationService.memberOrganizations$.pipe(
|
||||||
|
map((orgs) => orgs.sort(Utils.getSortFunction(this.i18nService, "name"))),
|
||||||
|
map((orgs) => {
|
||||||
|
if (!orgs.length) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [
|
||||||
|
// When the user is a member of an organization, make the "My Vault" option available
|
||||||
|
{
|
||||||
|
value: { id: MY_VAULT_ID } as Organization,
|
||||||
|
label: this.i18nService.t("myVault"),
|
||||||
|
icon: "bwi-user",
|
||||||
|
},
|
||||||
|
...orgs.map((org) => {
|
||||||
|
let icon = "bwi-business";
|
||||||
|
|
||||||
|
if (!org.enabled) {
|
||||||
|
// Show a warning icon if the organization is deactivated
|
||||||
|
icon = "bwi-exclamation-triangle tw-text-danger";
|
||||||
|
} else if (org.planProductType === ProductType.Families) {
|
||||||
|
// Show a family icon if the organization is a family org
|
||||||
|
icon = "bwi-family";
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
value: org,
|
||||||
|
label: org.name,
|
||||||
|
icon,
|
||||||
|
};
|
||||||
|
}),
|
||||||
|
];
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Folder array structured to be directly passed to `ChipSelectComponent`
|
||||||
|
*/
|
||||||
|
folders$: Observable<ChipSelectOption<FolderView>[]> = combineLatest([
|
||||||
|
this.filters$.pipe(
|
||||||
|
distinctUntilChanged(
|
||||||
|
(previousFilter, currentFilter) =>
|
||||||
|
// Only update the collections when the organizationId filter changes
|
||||||
|
previousFilter.organization?.id === currentFilter.organization?.id,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
this.folderService.folderViews$,
|
||||||
|
this.cipherViews$,
|
||||||
|
]).pipe(
|
||||||
|
map(([filters, folders, cipherViews]): [PopupListFilter, FolderView[], CipherView[]] => {
|
||||||
|
if (folders.length === 1 && folders[0].id === null) {
|
||||||
|
// Do not display folder selections when only the "no folder" option is available.
|
||||||
|
return [filters, [], cipherViews];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sort folders by alphabetic name
|
||||||
|
folders.sort(Utils.getSortFunction(this.i18nService, "name"));
|
||||||
|
let arrangedFolders = folders;
|
||||||
|
|
||||||
|
const noFolder = folders.find((f) => f.id === null);
|
||||||
|
|
||||||
|
if (noFolder) {
|
||||||
|
// Update `name` of the "no folder" option to "Items with no folder"
|
||||||
|
noFolder.name = this.i18nService.t("itemsWithNoFolder");
|
||||||
|
|
||||||
|
// Move the "no folder" option to the end of the list
|
||||||
|
arrangedFolders = [...folders.filter((f) => f.id !== null), noFolder];
|
||||||
|
}
|
||||||
|
return [filters, arrangedFolders, cipherViews];
|
||||||
|
}),
|
||||||
|
map(([filters, folders, cipherViews]) => {
|
||||||
|
const organizationId = filters.organization?.id ?? null;
|
||||||
|
|
||||||
|
// When no org or "My vault" is selected, return all folders
|
||||||
|
if (organizationId === null || organizationId === MY_VAULT_ID) {
|
||||||
|
return folders;
|
||||||
|
}
|
||||||
|
|
||||||
|
const orgCiphers = cipherViews.filter((c) => c.organizationId === organizationId);
|
||||||
|
|
||||||
|
// Return only the folders that have ciphers within the filtered organization
|
||||||
|
return folders.filter((f) => orgCiphers.some((oc) => oc.folderId === f.id));
|
||||||
|
}),
|
||||||
|
map((folders) => {
|
||||||
|
const nestedFolders = this.getAllFoldersNested(folders);
|
||||||
|
return new DynamicTreeNode<FolderView>({
|
||||||
|
fullList: folders,
|
||||||
|
nestedList: nestedFolders,
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
map((folders) =>
|
||||||
|
folders.nestedList.map((f) => this.convertToChipSelectOption(f, "bwi-folder")),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Collection array structured to be directly passed to `ChipSelectComponent`
|
||||||
|
*/
|
||||||
|
collections$: Observable<ChipSelectOption<CollectionView>[]> = combineLatest([
|
||||||
|
this.filters$.pipe(
|
||||||
|
distinctUntilChanged(
|
||||||
|
(previousFilter, currentFilter) =>
|
||||||
|
// Only update the collections when the organizationId filter changes
|
||||||
|
previousFilter.organization?.id === currentFilter.organization?.id,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
this.collectionService.decryptedCollections$,
|
||||||
|
]).pipe(
|
||||||
|
map(([filters, allCollections]) => {
|
||||||
|
const organizationId = filters.organization?.id ?? null;
|
||||||
|
// When the organization filter is selected, filter out collections that do not belong to the selected organization
|
||||||
|
const collections =
|
||||||
|
organizationId === null
|
||||||
|
? allCollections
|
||||||
|
: allCollections.filter((c) => c.organizationId === organizationId);
|
||||||
|
|
||||||
|
return collections;
|
||||||
|
}),
|
||||||
|
switchMap(async (collections) => {
|
||||||
|
const nestedCollections = await this.collectionService.getAllNested(collections);
|
||||||
|
|
||||||
|
return new DynamicTreeNode<CollectionView>({
|
||||||
|
fullList: collections,
|
||||||
|
nestedList: nestedCollections,
|
||||||
|
});
|
||||||
|
}),
|
||||||
|
map((collections) =>
|
||||||
|
collections.nestedList.map((c) => this.convertToChipSelectOption(c, "bwi-collection")),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts the given item into the `ChipSelectOption` structure
|
||||||
|
*/
|
||||||
|
private convertToChipSelectOption<T extends ITreeNodeObject>(
|
||||||
|
item: TreeNode<T>,
|
||||||
|
icon: string,
|
||||||
|
): ChipSelectOption<T> {
|
||||||
|
return {
|
||||||
|
value: item.node,
|
||||||
|
label: item.node.name,
|
||||||
|
icon,
|
||||||
|
children: item.children
|
||||||
|
? item.children.map((i) => this.convertToChipSelectOption(i, icon))
|
||||||
|
: undefined,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a nested folder structure based on the input FolderView array
|
||||||
|
*/
|
||||||
|
private getAllFoldersNested(folders: FolderView[]): TreeNode<FolderView>[] {
|
||||||
|
const nodes: TreeNode<FolderView>[] = [];
|
||||||
|
|
||||||
|
folders.forEach((f) => {
|
||||||
|
const folderCopy = new FolderView();
|
||||||
|
folderCopy.id = f.id;
|
||||||
|
folderCopy.revisionDate = f.revisionDate;
|
||||||
|
|
||||||
|
// Remove "/" from beginning and end of the folder name
|
||||||
|
// then split the folder name by the delimiter
|
||||||
|
const parts = f.name != null ? f.name.replace(/^\/+|\/+$/g, "").split(NESTING_DELIMITER) : [];
|
||||||
|
ServiceUtils.nestedTraverse(nodes, 0, parts, folderCopy, null, NESTING_DELIMITER);
|
||||||
|
});
|
||||||
|
|
||||||
|
return nodes;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate collection & folder filters when the organization filter changes
|
||||||
|
*/
|
||||||
|
private validateOrganizationChange(organization: Organization | null): void {
|
||||||
|
if (!organization) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const currentFilters = this.filterForm.getRawValue();
|
||||||
|
|
||||||
|
// When the organization filter changes and a collection is already selected,
|
||||||
|
// reset the collection filter if the collection does not belong to the new organization filter
|
||||||
|
if (currentFilters.collection && currentFilters.collection.organizationId !== organization.id) {
|
||||||
|
this.filterForm.get("collection").setValue(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
// When the organization filter changes and a folder is already selected,
|
||||||
|
// reset the folder filter if the folder does not belong to the new organization filter
|
||||||
|
if (
|
||||||
|
currentFilters.folder &&
|
||||||
|
currentFilters.folder.id !== null &&
|
||||||
|
organization.id !== MY_VAULT_ID
|
||||||
|
) {
|
||||||
|
// Get all ciphers that belong to the new organization
|
||||||
|
const orgCiphers = this.cipherViews.filter((c) => c.organizationId === organization.id);
|
||||||
|
|
||||||
|
// Find any ciphers within the organization that belong to the current folder
|
||||||
|
const newOrgContainsFolder = orgCiphers.some(
|
||||||
|
(oc) => oc.folderId === currentFilters.folder.id,
|
||||||
|
);
|
||||||
|
|
||||||
|
// If the new organization does not contain the current folder, reset the folder filter
|
||||||
|
if (!newOrgContainsFolder) {
|
||||||
|
this.filterForm.get("folder").setValue(null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
41
apps/browser/src/vault/popup/views/popup-cipher.view.ts
Normal file
41
apps/browser/src/vault/popup/views/popup-cipher.view.ts
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
import { Organization } from "@bitwarden/common/admin-console/models/domain/organization";
|
||||||
|
import { ProductType } from "@bitwarden/common/enums";
|
||||||
|
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
|
||||||
|
import { CollectionView } from "@bitwarden/common/vault/models/view/collection.view";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extended cipher view for the popup. Includes the associated collections and organization
|
||||||
|
* if applicable.
|
||||||
|
*/
|
||||||
|
export class PopupCipherView extends CipherView {
|
||||||
|
collections?: CollectionView[];
|
||||||
|
organization?: Organization;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
cipher: CipherView,
|
||||||
|
collections: CollectionView[] = null,
|
||||||
|
organization: Organization = null,
|
||||||
|
) {
|
||||||
|
super();
|
||||||
|
Object.assign(this, cipher);
|
||||||
|
this.collections = collections;
|
||||||
|
this.organization = organization;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the bwi icon for the cipher according to the organization type.
|
||||||
|
*/
|
||||||
|
get orgIcon(): "bwi-family" | "bwi-business" | null {
|
||||||
|
switch (this.organization?.planProductType) {
|
||||||
|
case ProductType.Free:
|
||||||
|
case ProductType.Families:
|
||||||
|
return "bwi-family";
|
||||||
|
case ProductType.Teams:
|
||||||
|
case ProductType.Enterprise:
|
||||||
|
case ProductType.TeamsStarter:
|
||||||
|
return "bwi-business";
|
||||||
|
default:
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
import "jest-preset-angular/setup-jest";
|
||||||
|
|
||||||
// Add chrome storage api
|
// Add chrome storage api
|
||||||
const QUOTA_BYTES = 10;
|
const QUOTA_BYTES = 10;
|
||||||
const storage = {
|
const storage = {
|
||||||
|
|||||||
@@ -66,8 +66,7 @@ const moduleRules = [
|
|||||||
{
|
{
|
||||||
loader: "babel-loader",
|
loader: "babel-loader",
|
||||||
options: {
|
options: {
|
||||||
configFile: false,
|
configFile: "../../babel.config.json",
|
||||||
plugins: ["@angular/compiler-cli/linker/babel"],
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@bitwarden/cli",
|
"name": "@bitwarden/cli",
|
||||||
"description": "A secure and free password manager for all of your devices.",
|
"description": "A secure and free password manager for all of your devices.",
|
||||||
"version": "2024.5.0",
|
"version": "2024.6.0",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"bitwarden",
|
"bitwarden",
|
||||||
"password",
|
"password",
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ import { VaultTimeoutSettingsService } from "@bitwarden/common/abstractions/vaul
|
|||||||
import { TokenService } from "@bitwarden/common/auth/abstractions/token.service";
|
import { TokenService } from "@bitwarden/common/auth/abstractions/token.service";
|
||||||
import { AppIdService } from "@bitwarden/common/platform/abstractions/app-id.service";
|
import { AppIdService } from "@bitwarden/common/platform/abstractions/app-id.service";
|
||||||
import { EnvironmentService } from "@bitwarden/common/platform/abstractions/environment.service";
|
import { EnvironmentService } from "@bitwarden/common/platform/abstractions/environment.service";
|
||||||
|
import { LogService } from "@bitwarden/common/platform/abstractions/log.service";
|
||||||
import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service";
|
import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service";
|
||||||
import { ApiService } from "@bitwarden/common/services/api.service";
|
import { ApiService } from "@bitwarden/common/services/api.service";
|
||||||
|
|
||||||
@@ -21,8 +22,10 @@ export class NodeApiService extends ApiService {
|
|||||||
platformUtilsService: PlatformUtilsService,
|
platformUtilsService: PlatformUtilsService,
|
||||||
environmentService: EnvironmentService,
|
environmentService: EnvironmentService,
|
||||||
appIdService: AppIdService,
|
appIdService: AppIdService,
|
||||||
|
refreshAccessTokenErrorCallback: () => Promise<void>,
|
||||||
|
logService: LogService,
|
||||||
|
logoutCallback: () => Promise<void>,
|
||||||
vaultTimeoutSettingsService: VaultTimeoutSettingsService,
|
vaultTimeoutSettingsService: VaultTimeoutSettingsService,
|
||||||
logoutCallback: (expired: boolean) => Promise<void>,
|
|
||||||
customUserAgent: string = null,
|
customUserAgent: string = null,
|
||||||
) {
|
) {
|
||||||
super(
|
super(
|
||||||
@@ -30,8 +33,10 @@ export class NodeApiService extends ApiService {
|
|||||||
platformUtilsService,
|
platformUtilsService,
|
||||||
environmentService,
|
environmentService,
|
||||||
appIdService,
|
appIdService,
|
||||||
vaultTimeoutSettingsService,
|
refreshAccessTokenErrorCallback,
|
||||||
|
logService,
|
||||||
logoutCallback,
|
logoutCallback,
|
||||||
|
vaultTimeoutSettingsService,
|
||||||
customUserAgent,
|
customUserAgent,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -255,6 +255,8 @@ export class ServiceContainer {
|
|||||||
p = path.join(process.env.HOME, ".config/Bitwarden CLI");
|
p = path.join(process.env.HOME, ".config/Bitwarden CLI");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const logoutCallback = async () => await this.logout();
|
||||||
|
|
||||||
this.platformUtilsService = new CliPlatformUtilsService(ClientType.Cli, packageJson);
|
this.platformUtilsService = new CliPlatformUtilsService(ClientType.Cli, packageJson);
|
||||||
this.logService = new ConsoleLogService(
|
this.logService = new ConsoleLogService(
|
||||||
this.platformUtilsService.isDev(),
|
this.platformUtilsService.isDev(),
|
||||||
@@ -337,6 +339,7 @@ export class ServiceContainer {
|
|||||||
this.keyGenerationService,
|
this.keyGenerationService,
|
||||||
this.encryptService,
|
this.encryptService,
|
||||||
this.logService,
|
this.logService,
|
||||||
|
logoutCallback,
|
||||||
);
|
);
|
||||||
|
|
||||||
const migrationRunner = new MigrationRunner(
|
const migrationRunner = new MigrationRunner(
|
||||||
@@ -421,13 +424,19 @@ export class ServiceContainer {
|
|||||||
VaultTimeoutStringType.Never, // default vault timeout
|
VaultTimeoutStringType.Never, // default vault timeout
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const refreshAccessTokenErrorCallback = () => {
|
||||||
|
throw new Error("Refresh Access token error");
|
||||||
|
};
|
||||||
|
|
||||||
this.apiService = new NodeApiService(
|
this.apiService = new NodeApiService(
|
||||||
this.tokenService,
|
this.tokenService,
|
||||||
this.platformUtilsService,
|
this.platformUtilsService,
|
||||||
this.environmentService,
|
this.environmentService,
|
||||||
this.appIdService,
|
this.appIdService,
|
||||||
|
refreshAccessTokenErrorCallback,
|
||||||
|
this.logService,
|
||||||
|
logoutCallback,
|
||||||
this.vaultTimeoutSettingsService,
|
this.vaultTimeoutSettingsService,
|
||||||
async (expired: boolean) => await this.logout(),
|
|
||||||
customUserAgent,
|
customUserAgent,
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -485,7 +494,7 @@ export class ServiceContainer {
|
|||||||
this.logService,
|
this.logService,
|
||||||
this.organizationService,
|
this.organizationService,
|
||||||
this.keyGenerationService,
|
this.keyGenerationService,
|
||||||
async (expired: boolean) => await this.logout(),
|
logoutCallback,
|
||||||
this.stateProvider,
|
this.stateProvider,
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -660,7 +669,7 @@ export class ServiceContainer {
|
|||||||
this.sendApiService,
|
this.sendApiService,
|
||||||
this.userDecryptionOptionsService,
|
this.userDecryptionOptionsService,
|
||||||
this.avatarService,
|
this.avatarService,
|
||||||
async (expired: boolean) => await this.logout(),
|
logoutCallback,
|
||||||
this.billingAccountProfileStateService,
|
this.billingAccountProfileStateService,
|
||||||
this.tokenService,
|
this.tokenService,
|
||||||
this.authService,
|
this.authService,
|
||||||
|
|||||||
8
apps/desktop/desktop_native/Cargo.lock
generated
8
apps/desktop/desktop_native/Cargo.lock
generated
@@ -39,9 +39,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "anyhow"
|
name = "anyhow"
|
||||||
version = "1.0.80"
|
version = "1.0.86"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5ad32ce52e4161730f7098c077cd2ed6229b5804ccf99e5366be1ab72a98b4e1"
|
checksum = "b3d1d046238990b9cf5bcde22a3fb3584ee5cf65fb2765f454ed428c7a0063da"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "arboard"
|
name = "arboard"
|
||||||
@@ -83,9 +83,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "base64"
|
name = "base64"
|
||||||
version = "0.22.0"
|
version = "0.22.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "9475866fec1451be56a3c2400fd081ff546538961565ccb5b7142cbd22bc7a51"
|
checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bitflags"
|
name = "bitflags"
|
||||||
|
|||||||
@@ -14,9 +14,9 @@ manual_test = []
|
|||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
aes = "=0.8.4"
|
aes = "=0.8.4"
|
||||||
anyhow = "=1.0.80"
|
anyhow = "=1.0.86"
|
||||||
arboard = { version = "=3.3.2", default-features = false, features = ["wayland-data-control"] }
|
arboard = { version = "=3.3.2", default-features = false, features = ["wayland-data-control"] }
|
||||||
base64 = "=0.22.0"
|
base64 = "=0.22.1"
|
||||||
cbc = { version = "=0.1.2", features = ["alloc"] }
|
cbc = { version = "=0.1.2", features = ["alloc"] }
|
||||||
napi = { version = "=2.16.0", features = ["async"] }
|
napi = { version = "=2.16.0", features = ["async"] }
|
||||||
napi-derive = "=2.16.0"
|
napi-derive = "=2.16.0"
|
||||||
|
|||||||
@@ -127,7 +127,7 @@
|
|||||||
"entitlementsLoginHelper": "resources/entitlements.mas.loginhelper.plist",
|
"entitlementsLoginHelper": "resources/entitlements.mas.loginhelper.plist",
|
||||||
"hardenedRuntime": false,
|
"hardenedRuntime": false,
|
||||||
"extendInfo": {
|
"extendInfo": {
|
||||||
"LSMinimumSystemVersion": "10.15.0",
|
"LSMinimumSystemVersion": "12",
|
||||||
"ElectronTeamID": "LTZ2PFU5D6"
|
"ElectronTeamID": "LTZ2PFU5D6"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -18,8 +18,7 @@
|
|||||||
"yargs": "17.7.2"
|
"yargs": "17.7.2"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@tsconfig/node16": "1.0.4",
|
"@types/node": "20.14.1",
|
||||||
"@types/node": "18.19.29",
|
|
||||||
"@types/node-ipc": "9.2.3",
|
"@types/node-ipc": "9.2.3",
|
||||||
"typescript": "4.7.4"
|
"typescript": "4.7.4"
|
||||||
}
|
}
|
||||||
@@ -99,9 +98,10 @@
|
|||||||
"integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA=="
|
"integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA=="
|
||||||
},
|
},
|
||||||
"node_modules/@types/node": {
|
"node_modules/@types/node": {
|
||||||
"version": "18.19.29",
|
"version": "20.14.1",
|
||||||
"resolved": "https://registry.npmjs.org/@types/node/-/node-18.19.29.tgz",
|
"resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.1.tgz",
|
||||||
"integrity": "sha512-5pAX7ggTmWZdhUrhRWLPf+5oM7F80bcKVCBbr0zwEkTNzTJL2CWQjznpFgHYy6GrzkYi2Yjy7DHKoynFxqPV8g==",
|
"integrity": "sha512-T2MzSGEu+ysB/FkWfqmhV3PLyQlowdptmmgD20C6QxsS8Fmv5SjpZ1ayXaEC0S21/h5UJ9iA6W/5vSNU5l00OA==",
|
||||||
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"undici-types": "~5.26.4"
|
"undici-types": "~5.26.4"
|
||||||
}
|
}
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user